快速排序(Hoare版)

  

例子

9      18     7      4     3     21     1

一.递归的逻辑

    public void quick(int[]array,int left,int right){
        //终止条件
        if (left>=right){//这里为什么要取>,只取=号不行吗?
            return;
        }
 
        //
        int part=partition(array, left, right);
        //开始递归
        quick(array,left,part-1);
        quick(array,part+1,right);
    }

答:特殊情况数组 1  2  3  4  5 

1就是基准 下一次循环: left就会>right

 二.找基准和排序

问题:

1.左边做key,为啥右边end先走

2.array[end]<=key 和array[start]>=key 部分为什么要取=号

    public int partition(int[]array,int start,int end){
        int i=start;//保存下来
         int key=array[start];//保存下来
        while (start<end){
            //这里为什么要取=
            while (start<end&&array[end]>=key){//循环停下来的是比key小的数
                end--;
            }
            while (start<end&&array[start]<=key){
                start++;
            }
            Swap(array,start,end);
        }
        Swap(array,start,i);//最后一次交换
        return start;
    }

交换函数

   private void Swap(int[]array,int i,int j){
        int temp=array[i];
        array[i]=array[j];
        array[j]=temp;
    }

三.总结

1..时间复杂度:O(N*logN)

2. 空间复杂度:O(logN)
3. 稳定性:不稳定

四.缺点

在数量过大的情况下,递归的太深-栈溢出情况

回答: 快速排序Hoare法是一种常用的快速排序算法实现方法。它是由Tony Hoare在1960年提出的。Hoare法的基本思想是选择一个基准值,将待排序序列分成两部分,一部分是小于基准值的元素,另一部分是大于基准值的元素。然后对这两部分分别进行递归排序,最终将整个序列排序完成。具体实现过程如下: 1. 选择一个基准值,可以是序列中的任意一个元素。 2. 定义两个指针,一个指向序列的起始位置,一个指向序列的末尾位置。 3. 移动左指针,直到找到一个大于等于基准值的元素。 4. 移动右指针,直到找到一个小于等于基准值的元素。 5. 如果左指针小于等于右指针,则交换左右指针所指向的元素。 6. 继续移动左右指针,直到左指针大于右指针。 7. 将基准值与右指针所指向的元素交换。 8. 分别对基准值左边和右边的子序列进行递归排序。 通过以上步骤,每一次递归都会将基准值放置在正确的位置上,最终完成整个序列的排序。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* [【八大排序③】快速排序(动图演绎Hoare法、挖坑法、前后指针法)](https://blog.csdn.net/Living_Amethyst/article/details/125513838)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [快速排序常见3种方法(hoare、挖坑法、前后指针法)以及改进。](https://blog.csdn.net/tjh1998/article/details/122159488)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值