排序演算法(4) 氣泡排序

2021-07-14 09:32:11 字數 937 閱讀 3320

氣泡排序(bubble sort)

1.傳統的氣泡排序演算法

(1)演算法思想

當進行公升序的氣泡排序時,則從後往前,依次比較相鄰的兩個數,若前面的數大於後面的數,則進行交換。第一次迴圈結束後,待排序序列a[1..n]中的最小元素被交換到a[1]位置。經過n-1次迴圈,即可完成對a的排序。

若對a=(49,  38, 65,  97,  76,  13,  27,  49)進行氣泡排序,第1次迴圈元素的交換過程過程如下所示(雙向箭頭:交換):

氣泡排序的整個過程如下圖所示:

(2)偽**

bubble-sort(a)

1fori

← 1tolength[a] - 1

2do forj

downtoi + 1

3do ifa[j]j-1]

4thenexchange a[j] ↔ a[j-1]

(3)**實現

void bubblesort_1(int a,int n)

}high--;

for(j=high;j>low;j--) //反向冒泡,找最小值

{if(a[j]

排序演算法 氣泡排序

一.氣泡排序的過程 公升值排序 1.將第乙個記錄的關鍵字與第二個記錄的關鍵字進行比較,若key 1 key 2 則交換。然後比較第二個與第三個,依此類推,直到第n 1個與第n個比較為止,第一趟排序完後,記錄最大的關鍵字會被排在最後面。2.將記錄的前n 1個關鍵字進行第二趟比較交換,直到前n 1個中最...

排序演算法 氣泡排序

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

排序演算法 氣泡排序

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