第 26 题:如何理解快速排序?

Posted Noxus丶SJ

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第 26 题:如何理解快速排序?相关的知识,希望对你有一定的参考价值。

什么是快速排序?

在一个序列中随机找出一个数(称为基准元素),然后就是比基准元素小的数放在左边,比基准元素大的数放在右边,这样就将一个序列分成了两个子序列,然后再按照同样的方法把子序列再分成更小的子序列,直到不能分解为止

栗子

<img src="https://noxussj.top:3000/26/1.png"></img>

紫色:基准元素

绿色:比基准元素小的数

黄色:比基准元素大的数

算法描述

假设一组序列为 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

<img src="https://noxussj.top:3000/26/2.gif"></img>

如果还是看不懂这个图,那证明你还没理解快速排序
个人建议,最好拿笔和纸自己试着排列一下

参考资料
值得收藏的十大经典排序算法
漫画:什么是快速排序?(完整版)

文章的内容/灵感都从下方内容中借鉴

  • 【持续维护/更新 500+前端面试题/笔记】https://github.com/noxussj/In...
  • 【大数据可视化图表插件】https://www.npmjs.com/package...
  • 【利用 THREE.JS 实现 3D 城市建模(珠海市)】https://3d.noxussj.top/

以上是关于第 26 题:如何理解快速排序?的主要内容,如果未能解决你的问题,请参考以下文章

第 24 题:如何理解希尔排序?

第 25 题:如何理解归并排序?

第 30 题:如何理解基数排序?

第 27 题:如何理解堆排序?

第 22 题:如何理解选择排序?

第 22 题:如何理解选择排序?