冒泡排序定義
冒泡排序(Bubble Sort)也是一種簡單直觀的排序算法。它重復地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個算法的名字由來是因為越小的元素會經由交換慢慢"浮"到數列的頂端。
算法步驟
比較相鄰的元素。如果第一個比第二個大,就交換他們兩個。
對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最后一對。這步做完后,最后的元素會是最大的數。
針對所有的元素重復以上的步驟,除了最后一個。
持續每次對越來越少的元素重復上面的步驟,直到沒有任何一對數字需要比較。
具體Java代碼實現
/** * *@author g0rez *@data 2021-05-16 * */ public class 冒泡排序 { public static void main(String[] args) { int[] arr =new int[]{2,4,3,5,6,1,7,8,10,9}; arr=bubbleSort(arr); for(int i = 0;i<arr.length;i++){ System.out.print(arr[i]+" "); } } public static int[] bubbleSort(int[] arr){ if(arr.length==0) return arr; for(int i=0;i<arr.length;i++){ for(int j=0;j<arr.length-i-1;j++){ if(arr[j]>arr[j+1]){ int t=arr[j]; arr[j]=arr[j+1]; arr[j+1]=t; } } } return arr; } }