- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构实验报告
实验名称: 实验四——排序
学生姓名: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
- 2025年休闲食品健康化转型下的市场拓展策略与渠道创新报告[001].docx
- 农村电商服务站品牌建设:2025年运营模式创新与品牌传播报告.docx
- 2025年互联网金融平台合规整改与金融科技监管的合规监督与可持续发展策略.docx
- 2025年短视频平台内容监管与平台社会责任关系研究报告.docx
- 农产品溯源体系在农产品质量安全监管中的信用体系构建与实施策略研究.docx
- 2025年工业互联网平台数据备份与恢复策略创新方案探讨.docx
- 2025年线上法律咨询服务平台法律咨询行业竞争策略研究.docx
- 农业产业集群农产品流通体系构建与发展机制报告.docx
- 智能制造领航者:2025年3D打印技术在规模生产中的应用效果分析报告[001].docx
- 农村金融服务创新与农村金融消费者权益保护法规实施效果分析报告.docx
文档评论(0)