- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE
PAGE 2
《数据结构》实验报告
一、实验名称
实验三:排序
二、实验目的
通过本实验,加深对排序概念的理解,能够对三类不同排序方法进行复杂度分析。掌握简单排序方法、先进排序方法和基数排序方法的变化过程及算法设计与分析。
三、实验要求
(1)学生提前准备好实验报告,预习并熟悉实验步骤;
(2)遵守实验室纪律,在规定的时间内完成要求的内容;
(3)1~2人为1小组,实验过程中独立操作、相互学习;
四、实验内容及步骤
(一)选择排序算法的实现
1、正确设计程序,并编译、链接成可执行文件
(1)首先正确写出排序顺序表的结构体 typedef struct SqList
(2)正确写出选择排序算法 SelectSort
(3)写出主程序 main ,提供输入与输出操作
本程序的特点是对于用户给定的一组关键字序列(49,38,65,49,76,13,27,52),采用选择排序将其变成一个有序表,并输出排序结果。详见附1。
2、进行程序测试
直接运行可执行文件,观察输出结果,结果正确,如图 1 所示。
图1
3、算法的时间复杂度分析
本算法为二重循环,基本操作为“比较”与“交换”,二者的时间复杂度均为 O(n2),
由于二者是顺序结构,因此算法的整体时间复杂度为 T(n)= O(n2)。
(二)插入排序算法的实现
1、正确设计程序,并编译、链接成可执行文件
(1)首先正确写出排序顺序表的结构体 typedef struct SqList
(2)正确写出插入排序算法 InsertSort
(3)写出主程序 main ,提供输入与输出操作
本程序的特点是对于用户给定的一组关键字序列(49,38,65,97,76,13,27,49),采用插入排序将其变成一个有序表,并输出排序结果。详见附2。
2、进行程序测试
直接运行可执行文件,观察输出结果,结果正确,如图 2 所示。
图2
3、算法的时间复杂度分析
本算法为二重循环,基本操作为“比较”与“移动”,二者的时间复杂度均为 O(n2),由于二者是顺序结构,因此算法的整体时间复杂度为 T(n)= O(n2)。
五、实验小结
实验进行顺利,既了解了排序顺序表的特点,又对选择排序和插入排序算法进行了验证。实验过程中存在以下几个问题:
(1)对指针变量作为参数传递后的操作不是很理解,尤其是形参与实参之间的关系。
(2)对“结构体指针”的“-”操作不是很适应,与一般变量操作相差较大。
经过指导教师的认真帮助以及查阅 C 程序设计教材,问题基本得以解决,保证了实验的顺利进行。就今后还应进一步加强 C 语言的学习,掌握一门工具。
附1:源程序
#define SORT_LIST_MAXSIZE 20
typedef int KeyType;
typedef int InfoType;
typedef struct{
KeyType key;
InfoType otherinfo;
}RcdType;
typedef struct{
RcdType r[SORT_LIST_MAXSIZE+1];
int length;
}SortList;
void SelectSort(SortList *L)
{
RcdType W;
int i,j,k;
for(i=1;iL-length;i++){
j=i;
for(k=i+1;k=L-length;k++)
if(L-r[k].keyL-r[j].key) j=k;
if(i!=j){
W=L-r[j];
L-r[j]=L-r[i];
L-r[i]=W;
}
}
}
main()
{
SortList *L;
int i;
L-r[0].key=0;
L-r[1].key=49;
L-r[2].key=38;
L-r[3].key=65;
L-r[4].key=49;
L-r[5].key=76;
L-r[6].key=13;
L-r[7].key=27;
L-r[8].key=52;
L-length=8;
SelectSort(L);
printf(\n\n);
for(i=1;i=L-length;i++)
printf(%d\n,L-r[i].key);
}
附2:原程序
#define SORT_LIST_MAXSIZE 20
typedef int KeyType;
typedef int InfoType;
typedef struct{
KeyType key;
InfoType
您可能关注的文档
最近下载
- 2025海南琼海市菜篮子市场开发有限责任公司招聘10人(第1号)笔试参考题库附答案解析.docx VIP
- GB∕T 39758-2021 无障碍设计 盲文在标志、设备和器具上的应用.pdf
- CECS 720-2020 钢板桩支护技术规程(1).docx VIP
- 2025海南琼海市菜篮子市场开发有限责任公司招聘10人(第1号)笔试模拟试题及答案解析.docx VIP
- 法哲学原理第二讲导论-公开课件.ppt VIP
- 法哲学原理课件.pptx
- 轻型卒中临床诊疗中国专家共识(2024版).pptx VIP
- 广告语言的语用分析.docx VIP
- 期权基础知识课件.ppt VIP
- 轻型卒中临床诊疗中国专家共识(2024版).pptx VIP
文档评论(0)