排序算法之快速排序(Java描述)

快速排序
在这里插入图片描述

递归到它的祖坟上去


public class QuickSort {
    
    
	public static void main(String[] args) {
    
    
		int[] arr = {
    
    3,4,6,7,2,7,2,8,0,9,1};
		quickSort(arr, 0, arr.length-1);
		System.out.println(Arrays.toString(arr));
	}
	
	public static void quickSort(int[] arr, int start, int end){
    
    
		if(start < end){
    
    
			//把开始位置当做标准数
			int stard = arr[start];
			//记住需要排序的下标
			int low = start;
			int high= end;
			//循环找比标准数大的数和比标准数小的数
			while(low < high){
    
    
				//不用替换(右边的数字比标准数大)
				while(low < high && stard <= arr[high]){
    
    
					high--;
				}
				//使用右边的数字替换左边的数(比较后比标准数小的替换)
				arr[low] = arr[high];
				
				while(low < high && arr[low] <= stard){
    
    
					low++;
				}
				arr[high] = arr[low];
				
			}
			arr[low] = stard;
			quickSort(arr, 0, low);
			quickSort(arr, low+1, end);
		}
	}
}

时间复杂度
平均O(nlog2n)
最优O(nlog2n)
最坏O(n2)
空间复杂度
O(nlog2n)

猜你喜欢

转载自blog.csdn.net/qq_45864370/article/details/108817453