排序的方法有很多,快排算是一种相对高效的排序方法,往日写快排都是依照记忆中的代码,每次选取数组中第一个元素或者最后一个元素为关键字进行排序,今日被问到快排为什么要随机化时,发现自己完全答不上来?所以查阅书籍,重新学习快排。
首先对普通快排进行复杂度分析,快排的时间复杂度取决于递归的深度,为了方便表示,这里用递归树来解释快排的运行模式,以{5,1,9,3,7,4,8,6,2}{5,7,8,6,3,2,4,1,9}{1,2,3,4,5,6,7,8,9}为例;取第一个元素为关键数,递归树如下图所示:
第一、第三种情况分别是最优情况下的快排和最坏情况下的快排。对于第一种情况,其递归树的深度[log(2^n)]+1,假设快排所需总时间为t(n), 那么经过不多于n次比较后,开始第一次划分,可得不等式:
t(n)<=2t(n/2)+n;
t(n)<=2(2t(n/4)+n/2)+n;
…..
t(n)<=nt(1)+nlog(2^n);t(1)=0;
因此第一种情况时间复杂度0(nlogn).而对于第三种情况,第i次划分需要比较n-i次,比较总次数就等于n-1+n-2+…+1=n(n-1)/2次,故其时间复杂度为0(n^2).所以快排的速度会因选取的关键元素在序列中的位置的不同而产生较大波动。代码如下:
#include<iostream>

本文探讨了快速排序为何需要随机化,通过分析最优和最坏情况下的递归树,指出关键元素的选择影响排序效率。随机化可以避免极端情况,提高算法平均性能。文中还提到了三数取中等策略,以优化关键元素的选择,提高快排效率。

832

被折叠的 条评论
为什么被折叠?



