5分钟搞定快速排序

快速排序核心思想是每趟调整基准值的位置,将小于基准值的数左移,将大于基准值的数右移,这样确保基准值左侧的数小于基准值,右侧的数大于基准值。 在下一趟时,调整上一趟分割的两个区域的基准值位置,直到最后完成所有基准值的调整。

调整基准值的前提是选择一个合理的基准值,一般是指定某个位置的数或者随机某个位置的数作为基准值( 我这里取每个区域的第一个数 ) 。

调整基准值的过程大概描述:

1、取第一个数作为基准值,声明从前往后搜索指针 i ,从后往前搜索指针 j ;

2、从后往前找,比基准值大则指针 j 减一,直到找到一个比基准值小的数,并和基准值交换(交换完后此时基准值的位置在 j );

3、从后往前查找结束再从前往后找,比基准值小则指针 i 加一,直到找到一个比基准值大的数,并和基准值交换(交换完后此时基准值的位置在 i );

4、当指针 i 等于 j 时,结束当前趟数基准值的调整。

待排序的数组如下:

image

调整基准值的过程我举个例子吧:

第一趟基准值key取72,i=0,j=8;

从后往前找,找到一个比72小的值48,与72交换,此时i=0,j=7;

image

从后往前找并交换之后确定了48是在72的左侧了,那么从前往后找的时候就不需要再判断i位置上的元素了,所以i=i+1=1。再从i的位置往后找,找到一个比72大的值88,与72交换,此时i=2,j=7;

image

从前往后找并交换之后确定了88是在72的右侧了,那么从后往前找的时候就不需要再判断j位置上的元素了,所以j=j-1=6。再从j的位置往前找,找到一个比72小的值42,与72交换,此时i=2,j=4;

image

从后往前找并交换之后确定了42是在72的左侧了,那么从前往后找的时候就不需要再判断i位置上的元素了,所以i=i+1=3。再从i的位置往后找,此时没有找到一个比72大的数,那么当前趟结束,找到基准值的位置i=j=4;

所以第一趟结束后的数组排列是:

image

查找基准值的思路大概是这样子,条理清晰之后,剩下的也就是重复上面的操作了,因此代码写起来就比较简单了。

调整基准值代码的具体实现:

image

每趟找到基准值的位置后,对基准值左边的数据和右边的数据进行基准值的调整 ,直到最后没有可调整的数据,那也就排完序了。

具体代码实现:

image

所以最后输出的数组就是排好序的数组了。

关注公众号「吃菜长肉」,获取更多内容。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
合并排序和快速排序都是使用分治思想实现的排序算法,并且都可以使用递归来完成。 它们的区别主要体现在以下几个方面: 1. 时间复杂度: 快速排序的时间复杂度是O(nlog2n),而合并排序的时间复杂度也是O(nlog2n)。不过,平均来说,快速排序是最好的一种内部排序方法。 2. 空间使用: 快速排序是原地排序,而合并排序不是原地排序。合并排序需要额外的空间来协助合并两个有序数组。 3. 分治思路: 快速排序每次将数组一分为三(将排好序的那个数字摘出来),而合并排序每次将数组一分为二。 4. 排序方向: 合并排序是自上而下的分解,接着再自下而上的合并排序。而快速排序是边分解边排序,是自上而下的排序。 关于合并排序和快速排序的具体实现,我发现了一个C++的代码示例,其中使用了快速排序的思想,但是在快排中采用了二分地只排前n个的方法,以在n的复杂度内搞定排序。你可以参考这个示例来理解具体的实现过程。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [算法:C++ 实现 快速排序、归并排序](https://blog.csdn.net/weixin_44775255/article/details/124063700)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【C++】快速排序以及归并排序的算法总结及思想应用分析](https://blog.csdn.net/m0_57298796/article/details/127426894)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值