排序演算法 氣泡排序

2021-07-11 16:36:20 字數 904 閱讀 7562

這個方法的基本思路是:用第0個元素與第1個比較,如果第0個比第1個大,那麼交換它們的位置。然後第1個與第2個比較,前乙個比後乙個大,繼續交換它們的位置,這樣以此類推(公升序排列,總是將最大的存放在後面)。一輪迴圈結束以後,最大的元素就跑到了陣列的末尾。然後再這樣比較陣列的前n-1個元素,然後第二大的元素跑到陣列的倒數第二個位置……這樣以此類推,就能比較出所有元素了。值得注意的是,如果有一輪冒泡的過程中,並沒有任何元素發生位置的交換,那麼此時陣列已經有序了,不用繼續迴圈了。

時間複雜度:o(n2)

氣泡排序的要點:

1. 兩兩

—注意是相鄰的兩個元素的意思

;2. 如果有n個元素需要比較n-1次,每一輪減少1次比較

;3. 既然叫氣泡排序,那就是從下往上兩兩比較,所以看上去就跟泡泡往上冒一樣。

//氣泡排序

void bubblesort(parraylist list)

} //如果沒有發生任何交換,那麼陣列已經有序了

if(0 == change)

} }

//c++精簡版

int main()

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

}cout << a[i] << " "; }

cout << endl;

return 0;

}

注:選擇排序與氣泡排序的異同:

選擇排序

:每次找到最小的元素,但是它只是將最小元素與首位元素交換位置;

氣泡排序

:每次找到最大的元素,但是在查詢的過程中需要不斷地移動元素的位置。

選擇排序相較氣泡排序,移動的次數較少,所以選擇排序比氣泡排序效果更好點。

排序演算法 氣泡排序

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