选择排序及应用.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文档。上传文档
查看更多
算法的描述方式可以有多种多样,比如可以用自然语言,如英语,但这是必须保证每条指令都是确定的。借助图形也可以表示算法,称为流程图,但只适用于小而简单的算法。 下面首先用自然语言描述排序的算法: From those integers that are currently unsorted,find the smallest and place it next in the sorted list. (在当前所有未排序的整数中,找出最小的一个,把它放在当前有序表的最后一个位置。) 这句话充分描述了排序问题,但他并不是算法。因为其中有几处疑问。例如,没有告诉我们数据与结果的存储方式。 下面我们用混合的方式尝试构建算法,它部分是c语言,部分是英语: for (i=0;in;i++){ Examine list[i] to list[n-1] and suppose that the smallest integer is at list[min]; Interchange list[i] and list[min]; } 要把上述混合程序转换成真正的c语言,还必须实现两个已明确定义的子任务:找出最小值并与list[i]交换。其中交换可以用下面代码实现: 代码1: void swap(int *x, int *y){ int temp=*x; /*declares temp as an int and assignes to it the contents of what x points to*/ *x=*y; /*stores what y points to into the location where x points*/ *y=temp; /*places the contents of temp in location pointed by y*/ } 上面这段小程序也可以用宏来实现: #define SWAP(x,y,t) ((t)=(x),(x)=(y),(y)=t) 两种实现各有优点,函数实现更易读,宏实现适用于所有变量类型。 现在,我们转向第一个子任务。这时的比较方法与我前面说过的冒泡排序法基本思想非常类似。只是现在相互交换的不是数据,而是指针。在每进行完一轮扫描之后只进行一次实质性的数据交换,这对于系统来说节省了不少执行成本。这个子任务的实现我们称它为函数sort。程序中用到定义在stlib.h中的函数rand,它产生一系列随机数传给sort。 下面是这段代码的整体表述: 代码2: #include stdio.h #include stdlib.h #define MAX_SIZE 101 #define SWAP(x,y,t) ((t)=(x),(x)=(y),(y)=t) void sort(int[],int);/*selection sort*/ void main(void) { int i,n; int list[MAX_SIZE]; printf(Enter the number of numbers to generate: ); scanf(%d,n); if(n1||nMAX_SIZE){ fprintf(stderr,Improper value of n\n); exit(EXIT_FAILURE); } for (i=0;in;i++){ /* randomly generate numbers */ list[i]=rand()%100; printf(%d ,list[i]); } sort(list,n); printf(\nSorted array:\n); for(i=0;in;i++)/* print out sorted numbers */ printf(%d ,list[i]); printf(\n); getch(); } void sort(int list[],int n) { int i,j,min,temp; for(i=0;in-1;i++){ min=i; for(j=i+1;jn;j++){ if(list[j]list[min]) min=j; } SWAP(list[i],list[min],temp); } } 执行的结果如下: 排序好的数组比较经常的一项应用就是查找。这里来介绍一下折半查找: 假定n=1

文档评论(0)

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

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

1亿VIP精品文档

相关文档