- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构实验报告
实验名称: 实验四——排序
学生姓名:XX
班 级:
班内序号:
学 号:
日 期:
1.实验要求
实验目的:
通过选择实验内容中的两个题目之一,学习、实现、对比、各种排序的算法,掌握各种排序算法的优劣,以及各种算法使用的情况。
题目1:
使用简单数组实现下面各种排序算法,并进行比较。
排序算法如下:
插入排序;
希尔排序;
冒泡排序;
快速排序;
简单选择排序;
堆排序;
归并排序;
基数排序(选作);
其他。
具体要求如下:
测试数据分成三类:正序、逆序、随机数据。
对于这三类数据,比较上述排序算法中关键字的比较次数和移动次数(其中关键字交换记为3次移动)。
对于这三类数据,比较上述排序算法中不同算法的执行时间,精确到微妙。
对2和3的结果进行分析,验证上述各种算法的时间复杂度。
编写main()函数测试各种排序算法的正确性。
2. 程序分析
2.1 存储结构
存储结构:数组
0 A1 1 A2 2 A3 3 A4 4 A5 5 A6 …… …… N An-1
2.2 关键算法分析
一、关键算法:
1、插入排序
取排序的第二个数据与前一个比较
若比前一个小,则赋值给哨兵
从后向前比较,将其插入在比其小的元素后
循环排序
2、希尔排序
将数组分成两份
将第一份数组的元素与哨兵比较
若其大与哨兵,其值赋给哨兵
哨兵与第二份数组元素比较,将较大的值赋给第二份数组
循环进行数组拆分
3、对数据进行编码
取数组元素与下一个元素比较
若比下一个元素大,则与其交换
后移,重复
改变总元素值,并重复上述代码
4、快速排序
选取标准值
比较高低指针指向元素,若指针保持前后顺序,且后指针元素大于标准值,后指针前移,重新比较
否则后面元素赋给前面元素
若后指针元素小于标准值,前指针后移,重新比较
否则前面元素赋给后面元素
5、简单选择排序
从数组中选择出最小元素
若不为当前元素,则交换
后移将当前元素设为下一个元素
6、堆排序
生成小顶堆
将堆的根节点移至数组的最后
去掉已做过根节点的元素继续生成小顶堆
数组倒置
7、归并排序
将数组每次以1/2拆分,直到为最小单位
小相邻单位数组比较重排合成新的单位
循环直至完成排序
二、代码详细分析:
1、插入排序
关键代码:
取排序的第二个数据与前一个比较:if(r[i]r[i-1])
若比前一个小,则赋值给哨兵:r[0]=r[i];
从后向前比较,将其插入在比其小的元素后:for(j=i-1;r[0]r[j];j--)
{r[j+1]=r[j];a++;} r[j+1]=r[0];
循环排序
2、希尔排序
关键代码:
将数组分成两份:d=n/2
将第一份数组的元素与哨兵比较:for(int i=d+1;i=n;i++)
若其大与哨兵,其值赋给哨兵:if(r[0]r[i-d]){ r[0]=r[i];}
哨兵与第二份数组元素比较,将较大的值赋给第二份数组:for(j=i-d;j0r[0]r[j];j=j-d) {r[j+d]=r[j]; }
循环进行数组拆分:for(int;d=1;d=d/2)
3、冒泡排序
关键代码:
取数组元素与下一个元素比较: for(int i=1;ibound;i++)if(r[i]r[i+1])
若比下一个元素大,则与其交换: r[0]=r[i]; r[i]=r[i+1]; r[i+1]=r[0];
后移,重复:for(int i=1;ibound;i++)
改变总元素值,并重复上述代码:int bound=pos;
4、快速排序
关键代码:
选取标准值:r[0]=r[i]
比较高低指针指向元素,若指针保持前后顺序,且后指针元素大于标准值,后指针前移,重新比较:while(ijr[j]=flag) {j--;}
否则后面元素赋给前面元素:r[i]=r[j];
若后指针元素小于标准值,前指针后移,重新比较:while(ijr[i]=flag) {i++;}
否则前面元素赋给后面元素:r[j]=r[i];
5、简单选择排序
关键代码:
从数组中选择出最小元素: for(int j=i+1;j=n;j++)
{if(r[j]r[index]) index=j; }
若不为当前元素,则交换: if(index!=i) {r[0]=r[i]; r[i]=r[index]; r[index]=r[0];}
后移将当前元素设为下一个元素:for(int i=1;in;i++)
6、堆排序
关键代码:
生成小顶堆:while(j=m) {if(jmr[j]r[j+1]) {j++;}
if(r[i]r[j]) {break; }
else{ int x; x=r[i]; r[i]=r[j]
您可能关注的文档
- 数据库管理与开发-试卷A.doc
- cs104 数组枚举.doc
- 数据库系统原理第三章同步练习.ppt
- 数据库基础入门精通篇.ppt
- 数据库题库整理.pptx
- CRISPR技术最新总结.pptx
- CRAN传输解决方案及挑战.ppt
- 数据状态管理系统需求分析.doc
- CPS网站上线.ppt
- CSS基础知识讲解.ppt
- 人教版九年级英语全一册单元速记•巧练Unit13【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit9【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit11【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit14【单元测试·提升卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit8【速记清单】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit4【单元测试·提升卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit13【单元测试·基础卷】(原卷版+解析).docx
- 人教版九年级英语全一册单元速记•巧练Unit7【速记清单】(原卷版+解析).docx
- 苏教版五年级上册数学分层作业设计 2.2 三角形的面积(附答案).docx
- 人教版九年级英语全一册单元速记•巧练Unit12【单元测试·基础卷】(原卷版+解析).docx
文档评论(0)