排序演算法 氣泡排序plus

2021-10-07 04:19:19 字數 2223 閱讀 6025

常見的氣泡排序演算法**:

private

static

void

sort2

(int

arr)

} system.out.

print

("氣泡排序:第"

+(arr.length-i)

+"輪之後,陣列的順序:");

common.

print

(arr);}

}

示例陣列:int arr = ;

執行結果如下:

氣泡排序:第1輪之後,陣列的順序:6 4 1 5 7 8 2 3 9 

氣泡排序:第2輪之後,陣列的順序:4 1 5 6 7 2 3 8 9

氣泡排序:第3輪之後,陣列的順序:1 4 5 6 2 3 7 8 9

氣泡排序:第4輪之後,陣列的順序:1 4 5 2 3 6 7 8 9

氣泡排序:第5輪之後,陣列的順序:1 4 2 3 5 6 7 8 9

氣泡排序:第6輪之後,陣列的順序:1 2 3 4 5 6 7 8 9

氣泡排序:第7輪之後,陣列的順序:1 2 3 4 5 6 7 8 9

氣泡排序:第8輪之後,陣列的順序:1 2 3 4 5 6 7 8 9

我們發現:當第6輪之後,其實排序已經完成,可是我們還在排序,顯然這是浪費時間的。所以

改進思路:設定乙個標記,一輪下來沒有交換位置的說明已經有序,直接跳出大迴圈。

private

static

void

sort2

(int

arr)}if

(issort)

system.out.

print

("氣泡排序增強後:第"

+(arr.length - i)

+"輪之後,陣列的順序:");

common.

print

(arr);}

}

執行結果:

氣泡排序增強後:第1輪之後,陣列的順序:6 4 1 5 7 8 2 3 9 

氣泡排序增強後:第2輪之後,陣列的順序:4 1 5 6 7 2 3 8 9

氣泡排序增強後:第3輪之後,陣列的順序:1 4 5 6 2 3 7 8 9

氣泡排序增強後:第4輪之後,陣列的順序:1 4 5 2 3 6 7 8 9

氣泡排序增強後:第5輪之後,陣列的順序:1 4 2 3 5 6 7 8 9

氣泡排序增強後:第6輪之後,陣列的順序:1 2 3 4 5 6 7 8 9

可是還有乙個問題?

比如有陣列int arr = ;

第一輪:3與4比較,

4與1比較,

4與2比較,

4與5比較,

5與6比較,

6與7比較,

7與8比較,

8與9比較,

第二輪:1與3比較,

3與2比較,

3與4比較,

4與5比較,

5與6比較,

6與7比較,

7與8比較,

8與9比較,

可以發現在第二輪,明明第一輪已經比較了,有序的了還在比較。按照以前的演算法,第二輪只有最後兩個才能是有序的,可實際的有序長度卻是大於2個,所以此演算法仍有改進的地方

改進思路,設定乙個邊界值變數,取代前面的第i次邊界值為i的情況,最後一次交換元素的位置就是下一輪的邊界值,後面的不交換則已經有序。

private

static

void

sort2

(int

arr)

} sortborder = lastexchangeindex;

if(issort)

system.out.

print

("氣泡排序增強後:第"

+(arr.length - i)

+"輪之後,陣列的順序:");

common.

print

(arr);}

}

這一版**中,sortborder就是無序數列的邊界。每一輪排序過程中,sortborder之後的元素就完全不需要比較了,肯定是有序的。

排序演算法 氣泡排序

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