氣泡排序 排序演算法簡介

2022-06-25 10:36:10 字數 999 閱讀 2419

根據排序過程中的主要操作,可以將內排序分為以下幾種:

插入排序:直接插入排序,希爾排序(改進的直接插入排序)

交換排序:氣泡排序,快速排序(改進的氣泡排序)

選擇排序:簡單選擇排序,堆排序(改進的簡單選擇排序)

歸併排序:歸併排序

本次主要介紹氣泡排序,接下來,將會陸續介紹以上各種排序演算法,以**加圖標的方法來展示上述排序演算法。

氣泡排序的基本思想:兩兩比較相鄰記錄的關鍵字,若反序則交換位置,直到沒有反序的記錄為止。

一. 氣泡排序

以順序表l = 為例,length = 5。**如下所示:

1

//氣泡排序法2//

順序表l中共有length個記錄

3void bubblesort1(sqlist*l)417

}18 }

順序表中的記錄變化如下所示:

二. 氣泡排序優化

以順序表l = 為例,length = 5。

對於該順序表,當 i = 2 時,沒有資料交換,此時,序列已經有序,若採用氣泡排序,則之後的迴圈判斷都是無意義的,所以我們加入了標記變數 flag 對氣泡排序進行優化。

**如下所示:

1

//氣泡排序優化2//

當剩餘數列已經有序時,則不需要在對後面的迴圈進行判斷3//

增加乙個標記變數flag來實現

4void bubblesort2(sqlist*l)522

}23} 24 }

順序表中的記錄變化如下所示:

簡單選擇排序

直接插入排序

希爾排序

堆排序 

歸併排序 

快速排序 

排序演算法 氣泡排序

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