- 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
- 剧本杀行业报告:内容创作规范与剧本市场拓展策略.docx
- 剧本杀行业区域市场区域文化特色与市场潜力分析报告.docx
- 剧本杀行业区域市场拓展实战案例研究.docx
- 剧本杀行业区域市场拓展路径与模式探索报告.docx
- 剧本杀行业区域市场竞争态势与品牌差异化策略研究报告.docx
- 剧本杀行业2025年西北区域市场市场细分领域竞争态势与品牌竞争策略分析研究报告.docx
- 剧本杀行业2025年西北市场拓展前景预测报告.docx
- 剧本杀行业2025年长沙市场发展潜力分析报告.docx
- 剧本杀行业2025年长三角市场竞争策略与布局分析.docx
- 医疗行业数据合规:2025年数据安全法实施后的合规监管挑战与应对.docx
最近下载
- 《第一单元 生活中的音乐学习项目二 音乐开启心灵之窗》教案(表格式)七年级音乐人教版(2024新版).pdf VIP
- 成功标书大餐——15份浙江省自然科学基金申请书.pdf VIP
- (辽宁富士电梯)系统故障代码及说明.doc VIP
- 2025版高考政治全程一轮复习必修2第一单元生产资料所有制与经济体制第一课我国的生产资料所有制课件.pptx VIP
- 陕西省专业技术人员继续教育2025公需课《党的二十届三中全会精神解读与高质量发展》20学时题库及答案.docx VIP
- 伤口换药护理操作.pptx VIP
- 贵州01-贵州省居住建筑节能设计标准DBJ52-49-20082.pptx VIP
- 《2023年度中国展览数据统计报告》.docx
- 城市名居商住楼房地产估价报告.doc VIP
- [说明]富士变频器维修与故障处理.doc VIP
文档评论(0)