数据结构实验8排序.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文档。上传文档
查看更多
数据结构实验8排序

实验八 排序 一、实验目的 1. 熟悉掌握教材中所介绍的几种排序方法。 2. 学会分析各种内排序算法的性能 。 二、实验内容 随机产生20位整数 输入序列,编写程序,按下列排序方法将序列从小到大排序并输出。 冒泡排序 快速排序 三、实验步骤 1、冒泡排序 冒泡排序(BubbleSort)的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较。如此下去,直至最终完成排序。 2、快速排序 基本思想 快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。 设要排序的数组是A[0]……A[N-1],首先任意选取一个数据(通常选用第一个数据)作为关键数据,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一趟快速排序。一趟快速排序的算法是: 1)设置两个变量I、J,排序开始的时候:I=1,J=N-1; 2)以第一个数组元素作为关键数据,赋值给X,即 X=A[0]; 3)从J开始向前搜索,即由后开始向前搜索(J=J-1),找到第一个小于X的值,让该值与X交换; 4)从I开始向后搜索,即由前开始向后搜索(I=I+1),找到第一个大于X的值,让该值与X交换; 5)重复第3、4步,直到 I=J; 算法说明 首先为了避免产生的随机数过大,我们限定了了随机数为1-100之间,其次我们分别运用函数产生随机数两次,第一次为使用冒泡排序,第二次为使用快速排序。 测试结果 分析与探讨 在设计中除了注意冒泡排序和快速排序的原理外,还需要注意函数间的套用中出现的形参和实参的类型统一,以及交换两个数值时候,中介参数的使用。 附录:源代码 源代码列在附录中,要求程序风格清晰易理解,有充分的注释。有意义的注释行不少于30%。 #includestdio.h #includetime.h #includestdlib.h #includeiostream using namespace std; void QuickSort(int p[], int start, int end) { if (start = end) { return; } int i=0, j=0, tmp=0; i = start; j = end-1; do { while(p[i] p[end]) { i++; } while(p[j] = p[end]) { j--; } if (ij) { tmp = p[i]; p[i] = p[j]; p[j] = tmp; } else { tmp = p[i]; p[i] = p[end]; p[end] = tmp; } } while(ij); QuickSort(p, start, i-1); QuickSort(p, i+1, end); } void PrintArrary(int data[], int size) { for (int i=0; isize; ++i) { cout data[i] ; } coutendl; } void main() { int a[20],i,j,t,flag; int argc[20]; srand((unsigned)time(0)); for(i=0;i20;i++) a[i]=rand()%100; cout随机产生20个100以内的整数endl; for(i=0;i20;i++) cout a[i] ; for(i=0;i19;i++) /* 改进型冒泡法排序 */ { flag=0; for(j

文档评论(0)

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

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

1亿VIP精品文档

相关文档