快速排序的详细过程

 我来答
G电子数码问答
2022-12-15 · TA获得超过1072个赞
知道小有建树答主
回答量:7857
采纳率:100%
帮助的人:106万
展开全部

快速排序的详细过程如下:

快速排序是指寻找一个参考数值,将小于参考数值的数放在数组的左边,将大于参考数值的数放在数组的右边。具体的实现方法:

1、随机选取数组中的一个index,其数值作为参考数值。将参考数值保存,并与数组的第一个位置的数值进行交换;从数组的左边和右边分别开始判断。

2、当右边的数值满足大于参考数值后退一位;当右边的数值不满足大于参考数值,将当前在数值放入左边当前指向的位置,左边前进一位;紧接着判断左边的数值满足小于参考数值往后进一位,左边的数值不满足小于参考数值,将当前数值放入右边当前指向位置,右边前进一位。

3、直到左右指向的位置重合,结束上述判断,将参考数值放入重合点,返回 重合点的index。

4、以重合点出为分界线,分为两个子数组。子数组重复进行上述判断。

5、直到传入函数的数组大小为1,退出递归调用。

快速排序是指通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序。

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式