a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C > 正文

C語言冒泡排序算實現代碼

2020-01-26 14:30:37
字體:
來源:轉載
供稿:網友

冒泡排序是排序算法的一種,思路清晰,代碼簡潔,常被用在大學生計算機課程中。

“冒泡”這個名字的由來是因為越大的元素會經由交換慢慢“浮”到數列的頂端,故名。

這里以從小到大排序為例進行講解。

基本思想及舉例說明

冒泡排序的基本思想就是不斷比較相鄰的兩個數,讓較大的元素不斷地往后移。經過一輪比較,就選出最大的數;經過第2輪比較,就選出次大的數,以此類推。

下面以對 3  2  4  1 進行冒泡排序說明。

第一輪 排序過程
3  2  4  1    (最初)
2  3  4  2    (比較3和2,交換)
2  3  4  1    (比較3和4,不交換)
2  3  1  4    (比較4和1,交換)
第一輪結束,最大的數4已經在最后面,因此第二輪排序只需要對前面三個數進行再比較。

第二輪 排序過程
2  3  1  4 (第一輪排序結果)
2  3  1  4 (比較2和3,不交換)
2  1  3  4 (比較3和1,交換
第二輪結束,第二大的數已經排在倒數第二個位置,所以第三輪只需要比較前兩個元素。

第三輪 排序過程
2  1  3  4  (第二輪排序結果)
1  2  3  4  (比較2和1,交換)

至此,排序結束。

算法總結及實現

對于具有N個元素的數組R[n],進行最多N-1輪比較;

第一輪,逐個比較(R[1], R[2]),  (R[2], R[3]),  (R[3], R[4]),  …….  (R[N-1], R[N]) ;  最大的元素會被移動到R[N]上。

第二輪,逐個比較(R[1], R[2]),  (R[2], R[3]),  (R[3], R[4]),  …….  (R[N-2], R[N-1]);第二大元素會被移動到R[N-1]上。

。。。。

以此類推,直到整個數組從小到大排序。

下面給出了冒泡排序的一般實現和優化實現。一般實現是教科書里常見的實現方法,無論數組是否排序好了,都會進行N-1輪比較; 而優化實現,在數組已經排序好的情況下,會提前退出比較,減小了算法的時間復雜度。

#include<stdio.h>#include<stdlib.h>#define N 8void bubble_sort(int a[],int n);//一般實現void bubble_sort(int a[],int n)//n為數組a的元素個數{  //一定進行N-1輪比較  for(int i=0; i<n-1; i++)  {    //每一輪比較前n-1-i個,即已排序好的最后i個不用比較    for(int j=0; j<n-1-i; j++)    {      if(a[j] > a[j+1])      {        int temp = a[j];        a[j] = a[j+1];        a[j+1]=temp;      }    }  }}//優化實現void bubble_sort_better(int a[],int n)//n為數組a的元素個數{  //最多進行N-1輪比較  for(int i=0; i<n-1; i++)  {    bool isSorted = true;    //每一輪比較前n-1-i個,即已排序好的最后i個不用比較    for(int j=0; j<n-1-i; j++)    {      if(a[j] > a[j+1])      {        isSorted = false;        int temp = a[j];        a[j] = a[j+1];        a[j+1]=temp;      }    }    if(isSorted) break; //如果沒有發生交換,說明數組已經排序好了  }}int main(){  int num[N] = {89, 38, 11, 78, 96, 44, 19, 25};  bubble_sort(num, N); //或者使用bubble_sort_better(num, N);  for(int i=0; i<N; i++)    printf("%d ", num[i]);  printf("/n");  system("pause");  return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 久草在线国产 | 亚洲视频在线看 | 国产精品国产精品国产专区不卡 | 99在线视频观看 | 久久精品小视频 | 国产黄色大全 | 国产精品不卡视频 | 精品免费视频一区二区 | 成人一区二区在线 | 久久爱成人 | 日韩视频中文字幕 | 国产日韩欧美在线 | 欧美在线观看一区 | 久热热热 | 日本欧美国产 | 一级一级毛片 | 成人高清 | 精品无人乱码一区二区三区 | 91精品国产精品 | 国产在线1区| 欧洲亚洲一区 | 91亚洲国产成人久久精品网站 | 久久国产精品久久久久久 | 欧美成人精精品一区二区频 | 国产美女永久免费无遮挡 | 色综合天天综合网国产成人网 | 91久久国产综合久久91精品网站 | 亚洲九九精品 | 欧美秋霞 | 亚洲免费福利视频 | 欧美日韩在线不卡 | 牛牛影视成人午夜影视 | 精品久久久久久久 | 欧美日韩在线不卡 | 艹逼视频在线免费观看 | 九九热精品视频 | 日本电影网址 | 中文字幕在线视频网 | 久久人人看 | 久久在线视频 | 男女国产网站 |