排序演算法 氣泡排序

2022-06-21 20:36:11 字數 1186 閱讀 6375

氣泡排序演算法是一種穩定的排序演算法。

氣泡排序演算法原理如下:

1. 比較相鄰的元素。如果第乙個比第二個大,就交換他們兩個。

2. 對每一對相鄰元素做同樣的工作,從開始第一對到結尾的最後一對。在這一點,最後的元素應該會是最大的數。

3. 針對所有的元素重複以上的步驟,除了最後乙個。

4. 持續每次對越來越少的元素重複上面的步驟,直到沒有任何一對數字需要比較。

資料演示:

待排序序列: 10 7 15 2 5 27 13

0 第1輪:  7 10 2 5 15 13  比較6次 |  (相鄰兩個元素兩兩比較:分別是:7-10比較交換位置、10-15比較無需交換、15-2比較交換位置、15-5比較交換位置、15-27比較無需交換、27-13比較交換位置 【確定27】)

1 第2輪: 7 2 5 10 13 【15 27】 比較5次 (相鄰兩個元素兩兩比較:分別是:7-10比較無需交換、10-2比較交換位置、10-5比較交換位置、10-15比較無需交換、15-13比較交換位置 【確定15 27】)

2 第3輪: 2 5 7 10 【13 15 27】 比較4次 (相鄰兩個元素兩兩比較:分別是:7-2比較交換位置、7-5比較交換位置、7-10比較無需交換、10-13比較無需交換 【確定13 15 27】】)

3 第4輪: 2 5 7 【10 13 15 27】 比較3次 (相鄰兩個元素兩兩比較:分別是:2-5比較無需交換、5-7比較無需交換、7-10比較無需交換 【確定 10 13 15 27】)

4 第5輪: 2 5 【7 10 13 15 27】 比較2次 (相鄰兩個元素兩兩比較:分別是:2-5比較無需交換、5-7比較無需交換 【確定7 10 13 15 27】)

5 第6輪: 2 【5 7 10 13 15 27】 比較1次 (相鄰兩個元素兩兩比較:分別是:2-5比較無需交換 【確定5 7 10 13 15 27】)

6 第7輪: 【2 5 7 10 13 15 27】 比較0次 (相鄰兩個元素兩兩比較:只剩 2 【確定2 5 7 10 13 15 27】)

**實現:

function bubblesort($arr) 

for($i=0;$i<$len-1;$i++)

} }return $arr;

}print_r(bubblesort($arr));

排序演算法 氣泡排序

一.氣泡排序的過程 公升值排序 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,氣泡排序演算法指標 這裡的指標並不是實際的指標,只是為方便而假象的乙個類似指標的東西 從第乙個資料開始,與其後面的乙...