參考 維基百科中的氣泡排序
氣泡排序 (bubble sort) 是與插入排序擁有相等的執行時間,但是兩種演算法在需要的交換次數卻很大地不同。
在最壞的情況,氣泡排序需要 o(n2) 次交換。
氣泡排序演演算法的運作如下:
比較相鄰的元素。如果第乙個比第二個大,就交換他們兩個。
對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最後一對。這步做完後,最後的元素會是最大的數。
針對所有的元素重複以上的步驟,除了最後乙個。
持續每次對越來越少的元素重複上面的步驟,直到沒有任何一對數字需要比較。
function bubble_sort (array, length)}}
函式氣泡排序輸入乙個陣列名稱為array 其長度為lengthi 從0 到(length - 1
) j 從0 到(length - 1 -i)
如果array[j] > array[j + 1
] 交換array[j] 和array[j + 1
] 的值
如果結束
j迴圈結束
i迴圈結束
函式結束
i∈[0,n-1) //迴圈n-1遍
j∈[0,n-1-i) //
每遍迴圈要處理的無序部分
swap(j,j+1) //
兩兩排序(公升序/降序)
/*** 氣泡排序 */
public
class
bubble1 }}
return
arr;
}//定義遍歷輸出方法
public
static
void output(int
arr)
}public
static
void
main(string args) ;
int arr2 =bubblesort1(arr1);
output(arr2);
}}
排序演算法 氣泡排序
一.氣泡排序的過程 公升值排序 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,氣泡排序演算法指標 這裡的指標並不是實際的指標,只是為方便而假象的乙個類似指標的東西 從第乙個資料開始,與其後面的乙...