经典排序算法 - 冒泡排序Bubble sort
經典排序算法 - 冒泡排序Bubble sort
其原理是比較接近的數字22,按照從小到交換大或降序排列,
這樣一趟過去后,最大或最小的數字被交換到了最后一位,
然后再從頭開始進行兩兩比較交換,直到倒數第二位時結束,其余類似看樣例
樣例為從小到大排序,
原始待排序數組| 6 | 2 | 4 | 1 | 5 | 9 |
第一趟排序(外循環)
第一次兩兩比較6 > 2交換(內循環)
交換前狀態| 6 | 2 |?4 | 1 | 5 | 9 |
交換后狀態| 2 | 6 |?4 | 1 | 5 | 9 |
?
第二次兩兩比較,6 > 4交換
交換前狀態| 2?| 6 | 4 |?1 | 5 | 9 |
交換后狀態| 2?| 4 | 6 |?1 | 5 | 9 |
?
第三次兩兩比較,6 > 1交換
交換前狀態| 2 | 4?| 6 | 1 |?5 | 9 |
交換后狀態| 2 | 4?| 1 | 6 |?5 | 9 |
?
第四次兩兩比較,6 > 5交換
交換前狀態| 2 | 4 | 1?| 6 | 5 |?9 |
交換后狀態| 2 | 4 | 1?| 5 | 6 |?9 |
?
第五次兩兩比較,6 < 9不交換
交換前狀態| 2 | 4 | 1 | 5?| 6 | 9 |
交換后狀態| 2 | 4 | 1 | 5?| 6 | 9 |
?
第二趟排序(外循環)
第一次兩兩比較2 < 4不交換
交換前狀態| 2 | 4 |?1 | 5 | 6 | 9 |
交換后狀態| 2 | 4 |?1 | 5 | 6 | 9 |
?
第二次兩兩比較,4 > 1交換
交換前狀態| 2?| 4 | 1 |?5 | 6 | 9 |?
交換后狀態| 2?| 1 | 4 |?5 | 6 | 9 |
?
第三次兩兩比較,4 < 5不交換
交換前狀態| 2 | 1?| 4 | 5 |?6 | 9 |?
交換后狀態| 2 | 1?| 4 | 5 |?6 | 9 |
?
第四次兩兩比較,5 < 6不交換
交換前狀態| 2 | 1 | 4?| 5 | 6 |?9 |
交換后狀態| 2 | 1 | 4?| 5 | 6 |?9 |
?
第三趟排序(外循環)
第一次兩兩比較2 > 1交換
交換后狀態| 2 | 1 |?4 | 5 | 6 | 9 |
交換后狀態| 1 | 2 |?4 | 5 | 6 | 9 |
?
第二次兩兩比較,2 < 4不交換
交換后狀態| 1?| 2 | 4 |?5 | 6 | 9 |?
交換后狀態| 1?| 2 | 4 |?5 | 6 | 9 |
?
第三次兩兩比較,4 < 5不交換
交換后狀態| 1 | 2?| 4 | 5 |?6 | 9 |?
交換后狀態| 1 | 2?| 4 | 5 |?6 | 9 |
?
第四趟排序(外循環)無交換
第五趟排序(外循環)無交換
排序完成,輸出終于結果1 2 4 5 6 9
代碼僅供參考
static void bubble_sort(int[] unsorted){for (int i = 0; i < unsorted.Length; i++){for (int j = i; j < unsorted.Length; j++){if (unsorted[i] > unsorted[j]){int temp = unsorted[i];unsorted[i] = unsorted[j];unsorted[j] = temp;}}}}static void Main(string[] args){int[] x = { 6, 2, 4, 1, 5, 9 };bubble_sort(x);foreach (var item in x){Console.WriteLine(item);}Console.ReadLine();}?
冒泡排序動畫演示
?
版權聲明:本文博客原創文章。博客,未經同意,不得轉載。
轉載于:https://www.cnblogs.com/bhlsheji/p/4750360.html
總結
以上是生活随笔為你收集整理的经典排序算法 - 冒泡排序Bubble sort的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 怎么在泰山上进行攀岩活动?
- 下一篇: js函数中的参数的个数