网站大量收购独家精品文档,联系QQ:2885784924

【2017年整理】对冒泡排序和快速排序算法的改进.pdfVIP

【2017年整理】对冒泡排序和快速排序算法的改进.pdf

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
【2017年整理】对冒泡排序和快速排序算法的改进

第 12 卷  第 5 期 琼州大学学报 2005 年 10 月 28 日 Vol. 12  No. 5 Journal of Qiongzhou University Oct. 28. 2005 对冒泡排序和快速排序算法的改进 张广路 (海南师范学院数学系 ,海南 海口 571158) 摘  要 :探讨了排序在计算机程序设计中的重要性 ,并给出两种排序的新方法及算法的 C 语言实现. 关键词 :排序 ;原地置换 ;稳定排序 ;分支策略 ( ) 中图分类号:TP 311. 12   文献标识码 :A   文章编号 : 1008 - 6722 2005 05 - 0018 - 04   当今是计算机应用领域不断扩大、信息量迅速增加的时代。但由于计算机硬件自身的速度和存储空间是 有限的 ,所以提高计算机速度并节省存储空间便成了众多软件编制人员努力的方向。在众多措施中 ,排序操作 理应是程序设计人员重要考虑的方面之一。排序方法选择的得当与否直接影响程序执行的速度和辅助存储空 间的占用量。进而影响整个软件的性能。但目前已有的众多排序方法中 ,就其全面性而言很难找到一种被认 为是最好的方法 ,每种方法都有其优缺点。空间方面 : 目前最好的算法是仅占用一个记录的辅助存储空间。时 间方面:文献[1]提到快速排序是在同数量级的排序方法中是最好的一种内部排序 ,本文给出两种新的排序方 法 :分别为双向冒泡排序和双倍快速排序 ,空间所占的存储空为一个记录的存储空间。时间则明显优于文 献[1 ,272~277] 提到的冒泡排序和快速排序。是对冒泡排序和快速排序有较大改进的两种内部排序。 1  双向冒泡排序方法 1. 1 双向冒泡排序算法的基本思想 ( ) ( ) 对于输入的子序列L[low …High ]看成竖着排列的“气泡”,然后分别从上端 Low 向底端 High 扫描。在 扫描的过程中时刻注意两个相邻元素的顺序 ,保证上端的元素小于下端的元素 ,这样经过一趟扫描后就使 较大的元素沉到下面。然后再从底端向上端扫描 , 由于在前一趟扫描过程中最大的元素已经沉到最底端, 所以这次扫描最大的元素不再参加排序 ,将剩下的元素进行排序 ,排序的过程中保证使得底端元素大于顶 端元素。这样反复的扫描 ,并不断缩小排序空间 ,直到整个序列有序位置。这样直观上看 ,双向冒泡排序法 先让重的气泡沉到底下 ,然后让轻的气泡浮上来 ,然后再让大的气泡沉下去 ,让次轻的气泡浮上来 ,依次反 复 ,直到带排序列有序为止。 1. 2 双向冒泡排序的一个执行示例 假如我们的待排序列的初始关键字为 :   图 1 示例中 ,i = 1 说明在第一趟排序时的正向和反向排序 , 有箭头所示 ,在正序过程中注意保证 L [i ] L [i + 1 ] ,在反序过程 中注意保证L[i ] L[i - 1 ]. 1. 3 算法描述 算法是利用两个指针 low 和 high 记录带排序列区域 L [low … high ] ,用指针变量 t 记录在每趟扫描过程中最近一次交换记录的 位置 ,在每次扫描开始 t 的初始值分别为Low 或 high ,并且在扫描 结束后再让 t 和 low 或 high 进行比较 ,如果发现某次 t 值没有改 变 ,则说明序列已经有序 ,并且用 break 跳出循环 ,提前结束排序。 图 1  双向冒泡排序示例 1. 4 算法的 C 语言实现   收稿日期 :2005 - 06 - 29 ( )   作者简介 :张广路 1978 - ,女 ,黑龙江大庆人 ,海南师范学院数学系助教 ,在读硕士研究生.  第 5 期  

文档评论(0)

hhuiws1482 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:5024214302000003

1亿VIP精品文档

相关文档