- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(c语言快排函数详解
c语言快排函数详解
int cmp(const void *a, const void *b)
返回正数就是说 cmp 传入参数第一个要放在第二个后面, 负数就是传入参数第一个要放第二个前面, 如果是 0, 那就无所谓谁前谁后..
下面就把snoopy曾经写的介绍qsort的完整版贴出来好了,我想有与我一样经历的朋友也可以弄懂的:
很多人问这个东西.我以前也看了好久,今天翻到以前学快排的时候写的练习code,基本上能覆盖绝大部分用法了.里面有很多地方没判断相等的情况,按道理来说相等情况下应该返回0的,这个请看代码的时候注意.我尽量保证代码不出错了.下面的这些说明和问题都是个人原创,没查什么资料,所以不保证其完全正确性,在此表示个人不对出现的问题负任何责任,大家WA了或者干吗的不要怪我,不过至少目前来说我用起来是没问题的 :)** 关于快排函数的一些说明 **qsort,包含在stdlib.h头文件里,函数一共四个参数,没返回值.一个典型的qsort的写法如下qsort(s,n,sizeof(s[0]),cmp);其中第一个参数是参与排序的数组名(或者也可以理解成开始排序的地址,因为可以写s[i]这样的表达式,这个问题下面有说明); 第二个参数是参与排序的元素个数; 第三个三数是单个元素的大小,推荐使用sizeof(s[0])这样的表达式,下面也有说明 :) ;第四个参数就是很多人觉得非常困惑的比较函数啦,关于这个函数,还要说的比较麻烦...我们来讨论cmp这个比较函数(写成cmp是我的个人喜好,你可以随便写成什么,比如qcmp什么的).典型的cmp的定义是int cmp(const void *a,const void *b);返回值必须是int,两个参数的类型必须都是const void *,那个a,b是我随便写的,个人喜好.假设是对int排序的话,如果是升序,那么就是如果a比b大返回一个正值,小则负值,相等返回0,其他的依次类推,后面有例子来说明对不同的类型如何进行排序.在函数体内要对a,b进行强制类型转换后才能得到正确的返回值,不同的类型有不同的处理方法.具体情况请参考后面的例子.** 关于快排的一些小问题 **1.快排是不稳定的,这个不稳定一个表现在其使用的时间是不确定的,最好情况(O(n))和最坏情况(O(n^2))差距太大,我们一般说的O(nlog(n))都是指的是其平均时间.2.快排是不稳定的,这个不稳定表现在如果相同的比较元素,可能顺序不一样,假设我们有这样一个序列,3,3,3,但是这三个3是有区别的,我们标记为3a,3b,3c,快排后的结果不一定就是3a,3b,3c这样的排列,所以在某些特定场合我们要用结构体来使其稳定(No.6的例子就是说明这个问题的)3.快排的比较函数的两个参数必须都是const void *的,这个要特别注意,写a和b只是我的个人喜好,写成cmp也只是我的个人喜好.推荐在cmp里面重新定义两个指针来强制类型转换,特别是在对结构体进行排序的时候4.快排qsort的第三个参数,那个sizeof,推荐是使用sizeof(s[0])这样,特别是对结构体,往往自己定义2*sizeof(int)这样的会出问题,用sizeof(s[0)既方便又保险5.如果要对数组进行部分排序,比如对一个s[n]的数组排列其从s[i]开始的m个元素,只需要在第一个和第二个参数上进行一些修改:qsort(s[i],m,sizeof(s[i]),cmp);** 标程,举例说明 **No.1.手工实现QuickSort#include stdio.hint a[100],n,temp;void QuickSort(int h,int t){???? if(h=t) return;???? int mid=(h+t)/2,i=h,j=t,x;???? x=a[mid];???? while(1)???? {???????? while(a[i]x) i++;???????? while(a[j]x) j--;???????? if(i=j) break;???????? temp=a[i];???????? a[i]=a[j];???????? a[j]=temp;???? }???? a[mid]=a[j];???? a[j]=x;???? QuickSort(h,j-1);???? QuickSort(j+1,t);???? return;}int main(){???? int i;???? scanf(%d,n);???? for(i=0;
您可能关注的文档
- (江苏省苏州市2015年中考语文试题word版含答案.doc
- (CI战略在医院护理管理中的应用.doc
- (江苏省苏州市吴中区2012届九年级上学期期末测试语文试题无答案.doc
- (江苏省苏州市吴江区20122013学年七年级英语上学期期末考试试题牛津版.doc
- (江苏省苏州市吴江区20132014学年第一学期期末考试初一语文试卷及答案word版.doc
- (江苏省苏州市吴江区2014届下学期初中九年级5月模拟考试思品试卷.doc
- (江苏省苏州市吴江区青云中学20132014学年八年级上学期语文期中测试试题word版含答案.doc
- (Clibre2009License安装设置说明.doc
- (江苏省苏州市太仓市20132014学年八年级思品上学期期中教学质量调研测试试题.doc
- (SFC顺序功能图教程.doc
最近下载
- 物业市场拓展工作计划方案.docx VIP
- 贝壳加盟合同协议.docx VIP
- 部编版二年级上册道德与发治第1、2次集体备课.pdf VIP
- 2021环境影响评价报告公示:废催化剂综合利用环评报告.docx VIP
- 新解读《渠道防渗衬砌工程技术标准 GB_T 50600-2020》最新解读.docx VIP
- 聚醚改性的聚异氰酸酯组合物.pdf VIP
- 工程项目驻场运维方案(3篇).docx VIP
- 2022年“学宪法讲宪法”活动知识竞赛题库.docx VIP
- 食品生产许可培训课件.ppt
- 2025纪念中国人民抗日战争暨世界反法西斯战争胜利80周年主题党课传承抗战精神开创美好未来.pptx VIP
文档评论(0)