欢迎来到天天文库
浏览记录
ID:31482619
大小:152.00 KB
页数:10页
时间:2019-01-11
《数据结构排序实验报告》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、WORD完美整理版《数据结构》课程设计报告实验五排序一、需求分析:本演示程序用C++6.0编写,完成各种排序的实现,对输入的一组数字实现不同的排序方法,对其由小到大顺序输出。(1)分别对直接插入排序、希尔排序、冒泡排序、快速排序、选择排序、堆排序算法进行编写。(2)、对存储的函数即输入的数字进行遍历。(3)、初始化函数对输入的数字进行保存。(4)、主函数实现使用者操作界面的编写,对输入、选择、保存、输出的各种实现。这当中还包括了各个函数的调用的实现。(5)、程序所能达到的功能:完成对输入的数字的生成,范文范例参考指导WORD完美整理版并通过对各
2、排序的选择实现数字从小到大的输出。二、程序主要功能以及基本要求:(1)、设计一个菜单,格式如下:1、直接插入排序2、希尔排序3、冒泡排序4、快速排序5、选择排序6、堆排序7、退出(2)、选择不同的菜单但进行相应的排序,并给出排序的关键字序列。三、系统框架图:本程序包含了9个函数,它们分别是:(1)、直接插入排序的算法函数InsertSort()。(2)、希尔排序的算法函数ShellSort()。主函数(3)、冒泡排序算法函数BubbleSort()。操作界面的设计,函数的调用。对输入的数组进行遍历初始化各个排序算法函数(4)、快速排序的算法函数
3、Partition()。(5)、选择排序算法函数SelectSort()。(6)、堆排序算法函数HeapAdjust()。(7)、对存储数字的遍历函数Visit()。(8)、初始化函数InitSqList()。(9)、主函数main()。四、详细设计实现各个算法的主要内容,下面是各个函数的主要信息:(1)各个排序函数的算法:范文范例参考指导WORD完美整理版一、直接插入排序voidInsertSort(SqList&L){inti,j;for(i=2;i<=L.length;i++){if(L.r[i].key4、r[0]=L.r[i];L.r[i]=L.r[i-1];for(j=i-2;(L.r[0].key0){dk/=3;//减小增量for(i=dk;i<=L.length;i++){L.r[0].key=L.r[i].key;j=i;范文范例参考指导WORD5、完美整理版while((j>=dk)&&(L.r[j-dk].key>L.r[0].key)){L.r[j].key=L.r[j-dk].key;j-=dk;}L.r[j].key=L.r[0].key;}}}三、冒泡排序voidBubbleSort(SqList&L){inti,j;for(i=0;iL.r[j+1].key){flag=0;inttemp;temp=L.r[j].key;L.r[j].key6、=L.r[j+1].key;L.r[j+1].key=temp;}//若无交换说明已经有序if(flag==1)break;}范文范例参考指导WORD完美整理版}四、快速排序intPartition(SqList&L,intlow,inthigh){//分割区域函数L.r[0]=L.r[low];intpivotkey=L.r[low].key;//一般将顺序表第一个元素作为支点while(low=pivotkey)high--;L.r[low]=L.r[high];wh7、ile(low8、RD完美整理版{QSort(L,1,L.length);}五、简单选择排序voidSelectSort(SqList&L){intmin;intj;f
4、r[0]=L.r[i];L.r[i]=L.r[i-1];for(j=i-2;(L.r[0].key0){dk/=3;//减小增量for(i=dk;i<=L.length;i++){L.r[0].key=L.r[i].key;j=i;范文范例参考指导WORD
5、完美整理版while((j>=dk)&&(L.r[j-dk].key>L.r[0].key)){L.r[j].key=L.r[j-dk].key;j-=dk;}L.r[j].key=L.r[0].key;}}}三、冒泡排序voidBubbleSort(SqList&L){inti,j;for(i=0;iL.r[j+1].key){flag=0;inttemp;temp=L.r[j].key;L.r[j].key
6、=L.r[j+1].key;L.r[j+1].key=temp;}//若无交换说明已经有序if(flag==1)break;}范文范例参考指导WORD完美整理版}四、快速排序intPartition(SqList&L,intlow,inthigh){//分割区域函数L.r[0]=L.r[low];intpivotkey=L.r[low].key;//一般将顺序表第一个元素作为支点while(low=pivotkey)high--;L.r[low]=L.r[high];wh
7、ile(low8、RD完美整理版{QSort(L,1,L.length);}五、简单选择排序voidSelectSort(SqList&L){intmin;intj;f
8、RD完美整理版{QSort(L,1,L.length);}五、简单选择排序voidSelectSort(SqList&L){intmin;intj;f
此文档下载收益归作者所有