1 int pivotIndex, pivot, swapIndex; 2 3 void swap(int[] arr, int x, int y) { 4 int temp = arr[x]; 5 arr[x] = arr[y]; 6 arr[y] = temp; 7 } 8 9 void quickSort(int[] arr, int start, int end) { 10 if (end <= start) return; 11 12 pivotIndex = (start + end)/2; 13 pivot = arr[pivotIndex]; 14 swap(arr, pivotIndex, end); 15 swapIndex = start; 16 for (int i = start; i < end; i++) { 17 if (arr[i] <= pivot) { 18 swap(arr, i, swapIndex); 19 ++swapIndex; 20 } 21 } 22 swap(arr, swapIndex, end); 23 24 quickSort(arr, start, swapIndex-1); 25 quickSort(arr, swapIndex+1, end); 26 } 27 28 void draw() { 29 noLoop(); 30 int[] arr = {10, 5, 2, 3}; 31 quickSort(arr, 0, arr.length-1); 32 println(arr); 33 }
快速排序,說白了就是快啦,不過有兩種實現方式,一種普通,一種In-place,後面的比前面的佔用較少空間。oop
快排用分治法解決。ui
最佳時間複雜度:O(nlog n)spa
平均時間複雜度:O(nlog n)code
最差時間複雜度:O(n2)blog
空間複雜度:通常版本O(n),In-place O(log n)排序