比较排序的最小比较次数问题

发布于 2022-08-25 01:05:24 字数 58 浏览 9 评论 0

为什么用任何一个基于“比较”的排序算法对 5 个元素进行排序在最坏情况下所需的比较次数至少为 7 次?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

空气里的味道 2022-09-01 01:05:24

先上结论:基于比较的排序每次进行关键字比较的排序的严格时间复杂度为Omega(nlog2(n))
原理在于:
基于比较能获得的信息有限,根据信息熵每次比较能获得两个数之间的关系
而对于n个元素的排序,共有n!种排列
故最坏情况需要的比较次数为log2(n!)

——————

另一类原理:
n个数的排列有n!种,
一次比较能从候选中排除一半,
最坏情况下需要log2(n!)次才能得到最终可能的结果

对于5个元素,共5!=120种排列
需要的比较次数为 log2(120) 约等于 6.9,向上取整得到7

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文