第 26 题:如何理解快速排序?
2021/8/19 13:36:10
本文主要是介绍第 26 题:如何理解快速排序?,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
什么是快速排序?
在一个序列中随机找出一个数(称为基准元素),然后就是比基准元素小的数放在左边,比基准元素大的数放在右边,这样就将一个序列分成了两个子序列,然后再按照同样的方法把子序列再分成更小的子序列,直到不能分解为止
栗子
紫色:基准元素
绿色:比基准元素小的数
黄色:比基准元素大的数
算法描述
假设一组序列为 6, 9, 2, 4, 5, 1, 8, 7
首先随机找一个数(6)
判断比 6 小的放在左边,大的放在右边
结果:2, 4, 5, 1, 6, 9, 8, 7
得到 2 个新的序列,左边(2, 4, 5, 1),右边(6, 8, 7)
-------------------------------------------------
然后对左边序列进行拆分,右边序列就不列举了
序列 2, 4, 5, 1
随机找一个数(2)继续进行判断,比 2 小的放在左边,大的放在右边
结果:1, 2, 4, 5
得到 2 个新的序列,左边(1),右边(4, 5)
-------------------------------------------------
然后发现左边序列(1)不能够进行拆分,所以要进行向上合并
右边序列(4, 5)可以继续拆分
随机找一个数(4)继续进行判断,比 4 小的放在左边,大的放在右边
结果:4, 5
得到新的序列,左边(4),右边(5)
然后发现左边序列(4)和右序列(5)不能够进行拆分,所以要进行向上合并
-------------------------------------------------
所有元素向上合并后得到结果
1, 2, 4, 5, 6, 7, 8
如果还是看不懂这个图,那证明你还没理解快速排序
个人建议,最好拿笔和纸自己试着排列一下
这篇关于第 26 题:如何理解快速排序?的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-15matplotlib作图不显示3D图,怎么办?
- 2024-06-1503-Loki 日志监控
- 2024-06-1504-让LLM理解知识 -Prompt
- 2024-06-05做软件测试需要懂代码吗?
- 2024-06-0514-ShardingSphere的分布式主键实现
- 2024-06-03为什么以及如何要进行架构设计权衡?
- 2024-05-31全网首发第二弹!软考2024年5月《软件设计师》真题+解析+答案!(11-20题)
- 2024-05-31全网首发!软考2024年5月《软件设计师》真题+解析+答案!(21-30题)
- 2024-05-30【Java】百万数据excel导出功能如何实现
- 2024-05-30我们小公司,哪像华为一样,用得上IPD(集成产品开发)?