- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)