排序演算法 氣泡排序

2021-09-29 01:25:22 字數 958 閱讀 1871

今天是國慶上班回來的第一天,心還沒辦法收斂,還是想著玩,哈哈。完全不在狀態,感覺一天效率極差,需要靜下心去做點事。無意中看到別人的一篇部落格,於是突發奇想,不如寫寫資料結構的知識吧,雖然日常見到這類部落格很多,覺得沒太大的新鮮味道。為了靜下心來,同時當複習多年前學習過且日常離不開的知識,後面每天一練。加油!!!

現在複習的第一篇是氣泡排序演算法,演算法原理比較簡單,見度娘的解釋:

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

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

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

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

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

直接上**,使用的是c++實現,在交換值時是兩種不同的思路:

#include using namespace std;

//氣泡排序演算法1

int bubblesort_1(int *data, int sizeofdata)

else

}} return 0;

}//氣泡排序演算法2

int bubblesort_2(int* data, int sizeofdata)

} }return 0;

}int main()

; int sizeofdata = 11;

//bubblesort_1(data, sizeofdata);

bubblesort_2(data, sizeofdata);

for (int i = 0; i < sizeofdata; i++)

}

-3-21

3457

891018

兩種方法都測試過,都能正確排序,並沒有大資料測試過,但從分析角度看,第一種方法相對高效一些。

排序演算法 氣泡排序

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