什么情况下使用快速排序比较快

 我来答
a399495
2011-07-01 · TA获得超过243个赞
知道答主
回答量:48
采纳率:100%
帮助的人:70.6万
展开全部
在分区时两个子分区最平衡时。
因为两个子分区大小不可能同时大于n/2,所以一个分区大小为n/2的下界,另一个分区大小为n/2的上界加1时,快速排序的运行速度最快。
这时,表达其运行时间的递归式为
T(n) <= 2T(n/2) + O(n)
根据定理
T(n) =
if n = 1 , then O(n)
if n > 1, then 2T(n/2) + O(n)
的解为T(n) = O(nlgn)
由于在每一层递归上,划分的两边都是对称的。所以,从渐进意义上来看,算法运行得最快。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
058vpstyx
2011-07-01 · TA获得超过3013个赞
知道大有可为答主
回答量:4450
采纳率:0%
帮助的人:774万
展开全部
双向排序是最快的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
手机用户05260
2011-07-01
知道答主
回答量:18
采纳率:0%
帮助的人:0
展开全部
啊十大撒上的
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式