数据结构产生随机数并排序-副本.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文档。上传文档
查看更多
数 据 结 构 课 程 设 计 学部:信息科学与技术学部 专业:计算机科学与技术 目录 一、 1 二、实验目的和要求 1 三、实验内容和原理 1 四、实验环境 1 五、自定义函数 2 1.生成随机数的函数 2 2.快速排序函数 2 3.堆排序函数 3 4.显示函数 3 5.主函数 4 六、运行截图 4 七、代码清单 5 实验题目 排序综合 利用随机函数产生N个随机整数,对这些数方法排序排序排序。 C++6.0 五、自定义函数 1.生成随机数的函数 /*--------------------产生随机数-------------------*/ void creat(sqlist *l) { int i; printf(请输入要产生的随机数个数:); scanf(%d,l-length); srand((unsigned)time(NULL)); //给srand()提供一个种子,它是一个unsigned int类型, for(i=1;i=l-length;i++) { l-r[i].key = rand() %900+100; //调用rand(),返回一个随机数(在0到32767之间) printf(%d ,l-r[i].key); } printf(\n); } 2.快速排序函数 /*交换顺序表中子表r[low...high]的记录,使枢轴记录到位,并返回其所在的位置*/ int partion(sqlist *l,int low,int high) { int pivotkey; l-r[0]=l-r[low]; //用子表的第一个记录作枢轴记录 pivotkey=l-r[low].key; //枢轴记录关键字 while(lowhigh) //从表的两端交替的向中间扫描 { while(lowhighl-r[high].key=pivotkey) --high; l-r[low]=l-r[high]; //将比枢轴记录小的记录移到低端 while(lowhighl-r[low].key=pivotkey) ++low; l-r[high]=l-r[low]; //将比枢轴记录大的记录移到低端 } l-r[low]=l-r[0]; //枢轴记录到位 return low; //返回枢轴位置 } /*--------------快速排序------------------*/ void Qsort(sqlist *l,int low,int high) { int pivotloc; if(lowhigh) //长度大于1 { pivotloc=partion(l,low,high); //将l.r[low..high]一分为二 Qsort(l,low,pivotloc-1); //对低子表递归排序 Qsort(l,pivotloc+1,high); //对高子表递归排序 } } 3.堆排序函数 /*调整h-r[s]的关键字,使h-r[s]成为一个大顶堆*/ void heapadjust(sqlist *h,int s,int m) { keytype rc; int j; rc=h-r[s]; for(j=2*s;j=m;j*=2) { if(jmh-r[j].keyh-r[j+1].key) ++j; if(rc.key=h-r[j].key) break; h-r[s]=h-r[j]; s=j; } h-r[s]=rc; } /*对顺序表h进行堆排序*/ void heapsort(sqlist *h) { keytype rc;int i; for(i=h-length/2;i0;--i) heapadjust(h,i,h-length); for(i=h-length;i1;--i) { rc=h-r[1]; h-r[1]=h-r[i]; h-r[i]=rc; heapadjust(h,1,i-1); } } 4.显示函数 /*显示顺序表*/ void display(sqlist *l) { int i; f

文档评论(0)

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

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

1亿VIP精品文档

相关文档