快速排序(JAVA)


快速排序

英文:QuickSort

一、快速排序原理

  1. 从待排序区间选择一个数,作为基准值(pivot);
  2. Partition: 遍历整个待排序区间,将比基准值小的(可以包含相等的)放到基准值的左边,将比基
    准值大的(可以包含相等的)放到基准值的右边;
  3. 采用分治思想,对左右两个小区间按照同样的方式处理,直到小区间的长度 == 1,代表已经有序,或者小区间的长度 == 0,代表没有数据。

在这里插入图片描述

二、性能分析

时间复杂度:平均 O( n * log(n) )
在这里插入图片描述

空间复杂度:
在这里插入图片描述

稳定性:不稳定

三、代码实现

1.原理

在这里插入图片描述

代码如下(示例):

//快速排序
    public static void quickSort(int[] arr){
        //使用一个辅助方法进行递归
        //辅助方法多了两个参数,用来表示针对数组上的哪个区间
        //进行整理
        _quickSort(arr, 0 ,arr.length - 1);
    }

    //[left, right]
    public static void _quickSort(int[] arr, int left, int right){
        if(left >= right){
            //如果区间为空或者区间只有一个元素,不用排序
            return;
        }
        //使用 partition 方法来进行刚才描述的整理过程
        // index 就是 left 和 right 重合的位置,就是整理之后的基准值的位置
        int index = partition(arr, left, right);
        //递归处理左边区间
        _quickSort(arr, left, index - 1);
        //递归处理右边区间
        _quickSort(arr, index + 1, right);
    }

    private static int partition(int[] arr, int left, int right) {
        //选取基准值(以最右侧数为基准值)
        int v = arr[right];
        int i = left;
        int j = right;
        while(i < j){
           //先从左往右找到一个比基准值大的元素
            while (i < j && arr[i] <= v){
                i++;
            }
            //再从右往左找到一个比基准值小的元素
            while (i < j && arr[j] >= v){
                j--;
            }
            swap(arr, i, j);
        }
        //如果发现 i 和 j 重叠了,此时就需要把当前基准值元素
        // 和 i,j 重叠位置进行交换
        swap(arr, i, right);
        return i;
    }

2.main函数部分验证

代码如下(示例):

public static void main(String[] args) {
        int[] arr = {9,5,2,7,3,6,8};
        quickSort(arr);
        System.out.println(Arrays.toString(arr));
    }

四、如何优化

  1. 选择基准值很重要,通常使用几数取中法
  2. partition 过程中把和基准值相等的数也选择出来
  3. 待排序区间小于一个阈值时(例如 48),使用直接插入排序

总结

       以上就是今天要讲的内容,本文介绍了快速排序的使用,欢迎评论区留言,我们共同探讨问题!

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Wmx-98

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值