- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
lvjing数据结构课程设计.doc
学校:工程师范(高职部)
班级:计用052
姓名: 吕静
完成时间:7月10日
学号:
数据结构课程设计—排序
班级:计用052 姓名:吕静
内容简介
我此次设计的内容是关于排序的有关知识的设计,根据所学知识和平时的实践完成了此次的设计内容,虽不完美,但在实际应用极为广泛。
设计内容主要是关于插入排序、交换排序、选择排序、归并排序、、、、、、的应用,我此次设计主要用到的语句包括:for、whileif、 do…while、 case……..
首先,先是对排序的主程序的概括,即所应用到的有关语句
其次,是对主程序的调用,通过排列顺序选择恰当的语句完成所对应的程序。
然后,确立关键字及由一组记录组成的文件,而记录则由若干个数据项(或域)组成,其中有一项可用来标识一个记录,称为一个关键字项,该数据项的值成为关键字(可以是字类型的也可是字符类型的,根据问题的要求而定).
最后,通过所学将语句贯穿起来,实现函数的正确调用。
学习C语言最初应该知道怎样运用一些关键字来编写程序,类的关键字中专时代有所了解,但并不深入。进入大学后对此类的运用就比较广了。因此,学好运用好是致关重要的。
所谓排序,就是要整理文件中的记录,使得它按关键字递增(或递减)的次序排列起来。排序是是数据处理中经常运用的一种重要运算。由于排序在计算机中占有重要地位,所以必须熟悉内部排序的排序过程,记住各种算法的时间复杂度,以便实际应用。
排序:插入排序:1)直接插入排序 2)希尔排序
选择排序:1)直接选择排序 2)堆排序
交换排序:1)起泡排序 2)快速排序
归并排序:、、、、、、
二流程图
case1 case2 case3 case4 case5 case6
三.程序代码及分析
以下是我对排序的设计及难懂的问题:
#define n 8
typedef struct /定义记录为结构类型/
{int key; /关键字域/
}rectype;
rectype r[n]; /R为记录类型的数组/
(此段程序设计在每个程序的开始,必不可缺)
起泡排序:
bubblesort (r) /从下往上扫描的起泡排序/
rectype r[ ];
{ int i,j,noswap,w;
rectype temp;
for(i=0;in-1;i++) /做的是n-1趟排序/
{noswap=1; /置末交换标志/
for(j=n-1;j=i;j--) /从下往上扫描/
if(r[j+1].keyr[j].key) /交换记录/
{temp=r[j+1];
r[j+1]=r[j];
r[j]=temp;
noswap=0;}
if(noswap==0)
{ for(w=0;wn+1;w++)
printf(%d ,r[w]);
printf(\n);}
if(noswap) break; /本趟排序中未发生交换,则终止算法/
}} /BUBBLESORT/
注意:每一趟排序都使有序区增加了一个气泡,再经过n-1趟排序之后,有序区中就有n-1个气泡,而无序区中的气泡的重量总是大于等于有序区中的气泡的重量,所以,整个起泡排序过程至少需要n-1趟排序。
直接选择排序:
selectsort(r) /对R[0]到R[n-1]进行直接选择排序/
rectype r[];
{int i,j,k;
rectype temp;
for (i=0;in;i++) /作n-1趟选择排序/
{k=i;
for(j=i+1;jn;j++) /在当前无序区选关键字最小的记录R[k]/
if(r[j].keyr[k].key)
k=j;
if(k!=i)
{temp=r[i];
r[i]=r[k];
r[k]=temp;
for(j=0;jn;j++)
printf(%d ,r[j]);
printf(\n);
}}} /SELECTSOR
您可能关注的文档
最近下载
- 欧洲规范-NF P98-200-2-中文.pdf VIP
- 2024年3月30日河北省直遴选面试真题及答案解析(下午卷).doc VIP
- 2025年3月30日河北省直遴选面试真题及答案解析(下午卷).doc VIP
- 我国糖尿病视网膜病变临床诊疗指南(2022年).docx VIP
- 2024年3月31日河北省直遴选面试真题及答案解析(上午卷).doc VIP
- 《水泥混凝土路面施工及验收规范GBJ 97-1987》知识培训.pptx VIP
- 2024年海南省省属虚拟市儋州市兰洋镇招聘社区工作者真题及完整答案详解1套.docx VIP
- 公司员工关怀管理方案.docx VIP
- 西方烹饪英语课件资料.ppt VIP
- 2024年3月17日河北省直遴选笔试真题及答案深度解析.doc VIP
文档评论(0)