排序算法有不少,下面只是列舉了幾種常見的.算法
首先定義一個用於交換數組中2個值的方法數組
1 //用於交換的方法 2 public static void swap(Integer[] arr,int a,int b){ 3 int temp; 4 temp = arr[a]; 5 arr[a] = arr[b]; 6 arr[b] = temp; 7 }
冒泡排序 O(n^2)dom
1 public static void sort(Integer[] a){ 2 for (int i=0;i<a.length;i++) { 3 4 Boolean flag = true; 5 6 for (int j=a.length-2;j>=i;j--){ 7 8 if (a[j]>a[j+1]){ 9 swap(a,j,j+1); 10 flag = false; 11 } 12 } 13 14 if (flag){ 15 //數組已經有序 16 return ; 17 } 18 } 19 }
簡單選擇排序 O(n^2)測試
1 public static void sort(Integer[] arr){ 2 3 for (int i=0;i<arr.length;i++){ 4 int min = i; 5 for (int j=i+1;j<arr.length;j++){ 6 if (arr[j]<arr[min]){ 7 min = j; 8 } 9 } 10 if (min != i){ 11 swap(arr,i,min); 12 } 13 } 14 15 }
直接插入排序 O(n^2)spa
1 public static void sort(Integer[] arr){ 2 for(int i=1;i<arr.length;i++){ 3 if (arr[i]<arr[i-1]){ 4 int temp = arr[i]; 5 int j; 6 for (j=i-1;j>=0 && arr[j]>temp;j--){ 7 arr[j+1] = arr[j]; 8 } 9 arr[j+1] = temp; 10 } 11 } 12 }
希爾排序 O(nlog(n))~ O(n^2) 不穩定code
1 public static void sort(Integer arr[]){ 2 //增量,每次分組的間隔 3 int increment = arr.length; 4 //臨時變量 5 int temp; 6 int j; 7 while (increment>1){ 8 increment = increment / 3 +1; 9 for (int i= 0;i<arr.length;i=i+increment){ 10 temp = arr[i]; 11 for (j=i-increment;j>=0&&arr[j]>temp;j=j-increment){ 12 arr[j+increment] = arr[j]; 13 } 14 arr[j+increment] = temp; 15 } 16 } 17 }
快速排序 O(nlog(n))~ O(n^2) 不穩定blog
1 public static void sort(Integer[] arr,int left,int right){ 2 int i,j,temp,t; 3 if(left>right){ 4 return ; 5 } 6 i=left; 7 j=right; 8 //temp就是基準位 9 temp = arr[left]; 10 while (i<j) { 11 //先看右邊,依次往左遞減 12 while (temp<=arr[j]&&i<j) { 13 j--; 14 } 15 //再看左邊,依次往右遞增 16 while (temp>=arr[i]&&i<j) { 17 i++; 18 } 19 //若是知足條件則交換 20 if (i<j) { 21 t = arr[j]; 22 arr[j] = arr[i]; 23 arr[i] = t; 24 } 25 } 26 //最後將基準爲與i和j相等位置的數字交換 27 arr[left] = arr[i]; 28 arr[i] = temp; 29 //遞歸調用左半數組 30 sort(arr, left, j-1); 31 //遞歸調用右半數組 32 sort(arr, j+1, right); 33 }
用下面這段代碼作測試,每一個算法的大概時間(因我的電腦差別,數據可能有差別)排序
1 Integer arr[] = new Integer[10000]; 2 for (int i =0;i<arr.length;i++){ 3 arr[i]= new Random().nextInt(); 4 } 5 Long start = System.currentTimeMillis(); 6 sort(arr,0,arr.length-1); 7 Long end = System.currentTimeMillis(); 8 System.out.println(start); 9 System.out.println(end); 10 System.out.println("運行時間爲----"+(end-start)); 11 for (Integer i:arr) { 12 System.out.print(i+" "); 13 }
冒泡算法:430~550ms遞歸
簡單選擇排序:105~180msrem
直接插入排序:55~80ms
希爾排序:40~60ms
快速排序:5~10ms