数据结构实验报告三.docVIP

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

文档评论(0)

153****9595 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档