排序演算法 氣泡排序

2021-06-13 07:18:21 字數 582 閱讀 1135

一. 氣泡排序的過程(公升值排序)

1. 將第乙個記錄的關鍵字與第二個記錄的關鍵字進行比較,若key[1] > key[2], 則交換。然後比較第二個與第三個,依此類推,直到第n-1個與第n個比較為止,第一趟排序完後,記錄最大的關鍵字會被排在最後面。

2. 將記錄的前n-1個關鍵字進行第二趟比較交換,直到前n-1個中最大記錄的關鍵字落在第n-1個位置為止。

3. 重複上述操作,直到一趟過程中沒有任何交換操作為止。

二.  時間複雜度

一趟的比較次數為: n-1  , 則總的比較次數為: (1/2) * (n2-n) , 其時間複雜度為o(n2).

三. 氣泡排序**

#include int main()

; int i, j, temp;

int flag = 0;

for (i=0; i<10; i++)

}if (0 == flag)

}for (i=0; i<10; i++)

printf("%d\t", a[i]);

putchar('\n');

return 0;

}

排序演算法 氣泡排序

從基礎重新抓起。氣泡排序 每次從陣列頭到尾選出最大或者最小的,排到尾部或者頭部。以排序結果從小到大為例 每次從陣列中把最大的調換到末尾。eg.元素個數 count,需要找count 1次 外迴圈,最後一次不用再做比較了 每次從頭到末尾沒有確定的資料中找最大的 內迴圈 做法就是比較相鄰兩個元素的大小,...

排序演算法 氣泡排序

排序演算法是處理資料最基礎的演算法,掌握各種排序演算法有利以後遇到資料時的處理。首次學習,先學習氣泡排序。氣泡排序原理 對一組待排序資料x1,x2,x3,x4,x5,x6,x7.xn,氣泡排序演算法指標 這裡的指標並不是實際的指標,只是為方便而假象的乙個類似指標的東西 從第乙個資料開始,與其後面的乙...

排序演算法 氣泡排序

排序演算法 冒泡冒泡 從小到大排序 int a 5 a 0 a 1 a 2 a 3 a 4 5 4 3 2 1 4 3 2 1 5 第一輪比較 從a 0 開始依次拿相鄰兩個數比較 如果前面的大於後面的 a j a j 1 那麼兩個數交換 3 2 1 4 5 第二輪比較,從a 0 開始依次拿相鄰兩個數...