排序演算法 氣泡排序

2021-09-07 03:14:40 字數 1551 閱讀 9028

##本小節知識點:

1. 【了解】氣泡排序

2. 【掌握】氣泡排序的步驟

3. 【了解】練習

---##1.氣泡排序

- 氣泡排序(bubble sort,台灣譯為:泡沫排序或氣泡排序)是一種簡單的排序演算法。它重複 地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重複地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個演算法的名字由來 是因為越小的元素會經由交換慢慢「浮」到數列的頂端。

- 氣泡排序 分為: 大數下沉 小數上浮

---##2.氣泡排序

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

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

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

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

- 示例:

---##3.練習

- 輸入一組無序資料,使用氣泡排序法進行排序,並輸出。

```

1

//氣泡排序

23 #include 4

//交換演算法5//

列印輸出陣列的功能

6void printarray(int array,int

length)

711 printf("\n"

);12}13

14//

為了能夠交換功能模組化,需要使用傳位址來改變函式外的值

15//

要注意的是,引數需要傳入位址值,也就是通過&獲取變數的位址

16void swop(int *a,int *b)

1722

//沉底演算法

23void bubblesort(int a,int

n)2437}

38 printf("

完成一次遍歷替換***************=\n");

39}40}

41//

冒泡演算法

42void bubblesort2(int a,int

n)4349}

50 printf("

完成一次遍歷替換***************=\n");

51}52}

5354

int main(int argc, const

char *argv) ;

57 bubblesort2(a,5

);58 printarray(a,5

);59

return0;

60 }

備註:便於和陣列首個下標索引是0,範圍起始位置我表述為0。

演算法思路:外迴圈,因為冒泡(小的數往前移動)或者沉底(大的數往後靠)的次數一定是n-1次,所以迴圈範圍自然就是0~n-2內迴圈,比如沉底(大的數往後靠),比較的範圍(0~n)-->.....-->(0~1),也就是說到最後一次沉底,就是第0個數和第1個數比較,然後大的往後移。

關於冒泡(小的數往前移),同理。

排序演算法 氣泡排序

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