• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程问答 > 比较排序的最小比较次数问题

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

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-07

佚名通过本文主要向大家介绍了相遇次数问题,相遇次数问题公式,苹果回答问题错误次数,大便次数多是什么问题,堆排序算法的比较次数等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题:比较排序的最小比较次数问题
描述:

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


解决方案1:

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

——————

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

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


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • 2017-06-07 使用sortable进行排序,怎么获取数组前后变化?
  • 2017-06-07 Python:使用scrapy下载网站数据
  • 2017-06-07 (shell)Linux下的diff命令复杂度多少?
  • 2017-06-07 如何把Pythonpy文件编译成pyd文件
  • 2017-06-07 正则表达式一道正则表达式问题求解释
  • 2017-06-07 (python)urllib2urlopen传入一个Request为何会返回URLError?而传入固定url时可以返回HTTPError?
  • 2017-06-07 求教hibernate集合映射问题
  • 2017-06-07 如何简化shell命令
  • 2017-06-07 pyqt5如何处理QtWidgetsQTextEdit里面的文本内容,比如复制全部,在末尾插入,删除,获取文本内容等等
  • 2017-06-07 (shell)awk按某个位置的字符分隔的方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • c++builder60怎么添加七牛的c-sdk呢?
    • 快递地址那种行政区划数据库api哪里有?
    • python运行时查看对象状态
    • 在表单上传图片中用$ajax不成功
    • 如何发送邮件如何屏蔽电脑向外发送邮件,求实现思路!
    • 七牛新标准用户PHPuploadify上传图片全部是2KB大小
    • 个人认证之后能否上传任意类型文件?
    • flaskadd_url_rule怎么将一个类注册到多个网址
    • 我有一个50MB的文件,我只下载了20MB,就中断了,这个该怎么算呢?
    • 服务端对客户端的下拉刷新接口怎么写?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有