数据结构实验指导书09.doc

  1. 1、本文档共16页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第 PAGE \* Arabic 8 页 实验九 排序 9.1 实验目的: 熟悉掌握各种排序方法,深刻理解排序算法及其执行的过程; 学会分析各种排序算法的性能; 了解各种方法的优缺点,对于实际问题能够选择一种较好的排序方案。 9.2 实验要求: 复习课本中有关排序的知识; 用C语言完成算法和程序设计并上机调试通过; 撰写实验报告,给出算法思路或流程图和具体实现(源程序)、算法分析结果(包括时间复杂度、空间复杂度以及算法优化设想)、输入数据及程序运行结果(必要时给出多种可能的输入数据和运行结果)。 9.3 基础实验 [实验1] 实现直接插入排序算法 实验内容与要求: 编写一个程序实现直接插入排序过程,并输出{9,8,7,6,5,4,3,2,1,0}的排序过程。 分析: 算法思想参照课本。 参考程序: #include stdio.h #define MAXE 20 /*线性表中最多元素个数*/ typedef int KeyType; typedef char InfoType[10]; typedef struct /*记录类型*/ { KeyType key; /*关键字项*/ InfoType data; /*其他数据项,类型为InfoType*/ } RecType; void InsertSort(RecType R[],int n) /*对R[0..n-1]按递增有序进行直接插入排序*/ { int i,j,k; RecType temp; for (i=1;in;i++) { temp=R[i]; j=i-1; /*从右向左在有序区R[0..i-1]中找R[i]的插入位置*/ while (j=0 temp.keyR[j].key) { R[j+1]=R[j]; /*将关键字大于R[i].key的记录后移*/ j--; } R[j+1]=temp; /*在j+1处插入R[i]*/ printf( i=%d ,i); /*输出每一趟的排序结果*/ for (k=0;kn;k++) printf(%3d,R[k].key); printf(\n); } } void main() { int i,k,n=10; KeyType a[]={9,8,7,6,5,4,3,2,1,0}; RecType R[MAXE]; for (i=0;in;i++) R[i].key=a[i]; printf(\n); printf( 初始关键字 ); /*输出初始关键字序列*/ for (k=0;kn;k++) printf(%3d,R[k].key); printf(\n); InsertSort(R,n); printf( 最后结果 ); /*输出初始关键字序列*/ for (k=0;kn;k++) printf(%3d,R[k].key); printf(\n\n); } [实验2] 快速排序算法的应用 实验内容与要求: 编写一个程序,实现对某一张顺序表的快速排序算法。 分析: 快速排序算法每次任取一个记录的关键字为标准,将其余记录分为两组,将所有关键字小于或等于标准的记录都放在它的位置之前,将所有关键字大于标准的记录都放在它的位置之后。对这两组再进行快速排序,直到完全有序。每递归1次,递归深度加1。 参考程序: #includestdio.h typedef int node; node afile[20]; node x; int d,dl,n; int l,r,i,j; void q(int l,int r){ ??? int p; ??? d++; ??? if(dld) ?????? dl=d; ??? printf(dl=%d???? ,dl); ??? printf(d=%d\n,d); ??? if(lr){ ?????? i=l; j=r; ?????? x=afile[i]; ?????? while(i!=j){ ?????????? while((afile[j]x)(ji)) ????????????? j--; ??????????? if(ij) ????????????? afile[i++]=afile[j]; ?????????? while((afile[i]x)(ji)) ????????????? i++; ?????????? if(ij) ????????????? afile[j--]=afile[i]; ?????? ? } ?????? af

文档评论(0)

ccccccxx + 关注
官方认证
内容提供者

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

认证主体临沂冉通信息技术有限公司
IP属地山东
统一社会信用代码/组织机构代码
91371300MA9576790T

1亿VIP精品文档

相关文档