排序演算法 氣泡排序

2021-10-16 17:15:45 字數 1808 閱讀 4495

n個記錄進行氣泡排序的方法是:首先將第乙個記錄的關鍵字和第二個記錄的關鍵字進行比較,若為逆序,則交換,然後繼續比較;依次類推,直到比較n-1與n;這是第一趟氣泡排序。然後進行第二趟,對前n-1個遍歷排序,最多進行n-1趟。優化:若某趟沒有進行元素交換,則可以直接結束排序。

氣泡排序是一種穩定的排序方法,其時間複雜度為

演算法實現

//  非遞減有序排序

void bubblesort_asc(vector&data)

}// 本趟未發生位置交換,資料已排好序

if(*** == false)}}

//  非遞增有序排序

void bubblesort_desc(vector&data)

}// 本趟未發生位置交換,資料已排好序

if(*** == false)}}

//  排序,合併成乙個函式, bsort

// true : 非遞減有序排序

// false: 非遞增有序排序

void bubblesort(vector&data, const bool &bsort)

}// 本趟未發生位置交換,資料已排好序

if(*** == false)}}

#include #include #include #include using namespace std;

// 交換數值

void swapnum(int &a, int &b)

// 在控制台列印

void dadacout(const vector&data)

cout << endl;

}// 非遞減有序排序

void bubblesort_asc(vector&data)

}// 本趟未發生位置交換,資料已排好序

if(*** == false)

}}// 非遞增有序排序

void bubblesort_desc(vector&data)

}// 本趟未發生位置交換,資料已排好序

if(*** == false)

}}// 排序,合併成乙個函式, bsort

// true : 非遞減有序排序

// false: 非遞增有序排序

void bubblesort(vector&data, const bool &bsort)

}// 本趟未發生位置交換,資料已排好序

if(*** == false)

}}int main()

cout << "data: ";

dadacout(data);

bubblesort_asc(data);

cout << "bubblesort_asc: ";

dadacout(data);

bubblesort_desc(data);

cout << "bubblesort_desc: ";

dadacout(data);

bubblesort(data, true);

cout << "bubblesort_asc_true: ";

dadacout(data);

bubblesort(data, false);

cout << "bubblesort_desc_false: ";

dadacout(data);

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