排序演算法 氣泡排序

2021-07-14 02:20:54 字數 791 閱讀 9743

#include

using namespace std;

//氣泡排序

/*氣泡排序的思想很簡單,就是不斷將最大的元素往後移動,第一次掃瞄,會將最大的元素移動到最後,然後再用類似的方式排序前n-1個元素。

當然氣泡排序實現可以通過遞迴實現,也可以通過迴圈迭代實現。

*///使用遞迴實現的氣泡排序

void bubblesortbyrecursion(int list,int size)

}bubblesortbyrecursion(list,size-1);//將剩下的未排序的陣列進行排序

}//使用迭代實現的氣泡排序

void bubblesortbyiteration(int list,int size)

}//氣泡排序的改進

/*要知道氣泡排序的平均複雜度為o(n*n),可以通過一定的方式進行改善,如當某次排序移動元素的個數為0時,表示已經排好序,應停止。

*///優化後的氣泡排序

void bubblesortoptimize(int list,int size)

if(ncount==0)//當移動次數為0時,排序停止

break;}}

//此外快速排序也是對氣泡排序的改進,通過比較用遞迴實現的氣泡排序和用遞迴實現的快速排序,就能明白這一點了

//快速排序可參看:

int main()

;bubblesortoptimize(list,10);

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

cout

排序演算法 氣泡排序

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