排序算法简介.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构和算法 选择排序 选择排序分为简单选择排序,堆排序 简单选择排序: 从元素中寻找最小的元素,将它和第一位替换,依次类推 堆排序 首先知道什么是堆,堆是一颗二叉树,是满足什么条件的二叉树呢? 但Ki=K2i,Ki=K2i+1或者Ki=K2i,Ki=K2i+1 Eg:对46,79,56,38,40,84建立一个大顶堆,求初始堆 首先建立完全二叉树,插入规则是按层次遍历插入 调整二叉树,使其符合堆的规则,一半从n/2的元素开始 交换排序 交换排序分为冒泡排序,快速排序 57 68 59 52 从小到大排序 冒泡排序 快速排序 快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。   初始状态 {49 38 65 97 76 13 27}   进行一次快速排序之后划分为 {27 38 13} 49 {76 97 65} 分别对前后两部分进行快速排序 {27 38 13} 经第三步和第四步交换后变成 {13 27 38} 完成排序。 {76 97 65} 经第三步和第四步交换后变成 {65 76 97} 完成排序。//参照《数据结构》(C语言版)   //调用:quicksort--qsort--partitions   int partitions(int a[],int low,int high)   {   int pivotkey=a[low];   //a[0]=a[low];   while(lowhigh)   {   while(lowhigh a[high]=pivotkey)   --high;   a[low]=a[high];   while(lowhigh a[low]=pivotkey)   ++low;   a[high]=a[low];   }   //a[low]=a[0];   a[low]=pivotkey;   return low;   }   void qsort(int a[],int low,int high)   {   int pivottag;   if(lowhigh)   { //递归调用   pivottag=partitions(a,low,high);   qsort(a,low,pivottag-1);   qsort(a,pivottag+1,high);   }   }   void quicksort(int a[],int n)   {   qsort(a,0,n);   }   //简单示例   #include stdio.h   //#include math.h   #include myfunc.h //存放于个人函数库中   main()   {   int i,a[11]={0,11,12,5,6,13,8,9,14,7,10};   for(i=0;i11;printf(%3d,a[i]),++i);   printf(\n);   quicksort(a,10);   for(i=0;i11;printf(%3d,a[i]),++i);   printf(\n);   }Eg:57 68 59 52 72 28 96 33 [57 68] [59 52] [72 28] [96 33] 比较得到 [57 68] [52 59] [28 72] [33 96] 合并得到 [57 68 52 59] [28 72 33 96] 比较得到 [52 57 59 68] [28 33 72 96] 依次类推…… 基数排序 设待排序文件各记录的关键字为288,371,260,531,287,235,56,299,18,23。这时 r=10, d=3。进行3趟分配和3趟收集。 排序的对象有三位数以上,则持续进行以上的动作直至最高位数为止。 “基数排序法”(radix sort)则是属于“分配式排序”(distribution sort),基数排序法又称“桶子法”(bucket sort)或bin sort,顾名思义,它是透过键值的部份资讯,将要排序的元素分配至某些“桶”中,藉以达到排序的作用,基数排序法是属于稳定性的排序,其时间复杂度为O (nlog(r)m),其中r为所采取的基数,而m为堆数,在某些时候,基数排序法的效率高于其它的比较性排序法。 解法 基数排序的方式可以采用LSD(Least

文档评论(0)

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

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

1亿VIP精品文档

相关文档