ImageVerifierCode 换一换
格式:DOCX , 页数:35 ,大小:141.08KB ,
资源ID:3840998      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3840998.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构课程设计.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构课程设计.docx

1、数据结构课程设计 数据结构课程设计报告 几种排序算法的演示班级: 姓名: 学号: 完成日期:一 需求分析1.运行环境Microsoft Visual Studio 20082.程序所实现的功能对直接插入排序、折半插入排序、冒泡排序、简单选择排序、快速排序、堆排序、归并排序算法的演示,并且输出每一趟的排序情况。3.程序的输入(包含输入的数据格式和说明)排序种类三输入 排序数的个数的输入 所需排序的所有数的输入 4.程序的输出(程序输出的形式)主菜单的输出 每一趟排序的输出,即排序过程的输出5.测试数据,如果程序输入的数据量比较大,需要给出测试数据。二 设计说明1.算法设计思想交换排序(冒泡排序、

2、快速排序)交换排序的基本思想是:对排序表中的数据元素按关键字进行两两比较,如果发生逆序(即排列顺序与排序后的次序正好相反),则两者交换位置,直到所有数据元素都排好序为止。 插入排序(直接插入排序、折半插入排序)插入排序的基本思想是:每一次设法把一个数据元素插入到已经排序的部分序列的合适位置,使得插入后的序列仍然是有序的。开始时建立一个初始的有序序列,它只包含一个数据元素。然后,从这个初始序列出发不断插入数据元素,直到最后一个数据元素插到有序序列后,整个排序工作就完成了。 选择排序(简单选择排序、堆排序)选择排序的基本思想是:第一趟在有n个数据元素的排序表中选出关键字最小的数据元素,然后在剩下的

3、n-1个数据元素中再选出关键字最小(整个数据表中次小)的数据元素,依次重复,每一趟(例如第i趟,i=1,n-1)总是在当前剩下的n-i+1个待排序数据元素中选出关键字最小的数据元素,作为有序数据元素序列的第i个数据元素。等到第n-1趟选择结束,待排序数据元素仅剩下一个时就不用再选了,按选出的先后次序所得到的数据元素序列即为有序序列,排序即告完成。 归并排序(两路归并排序)两路归并排序的基本思想是:假设初始排序表有n个数据元素,首先把它看成是长度为1的首尾相接的n个有序子表(以后称它们为归并项),先做两两归并,得n/2上取整个长度为2的归并项(如果n为奇数,则最后一个归并项的长度为1);再做两两

4、归并,如此重复,最后得到一个长度为n的有序序列。2.程序的主要流程图3.程序的主要模块(要求对主要流程图中出现的模块进行说明)程序的主要模块主要分为主菜单模块和排序算法演示模块。 主菜单主要功能:程序运行时,可使运行者根据提醒输入相关操作,从而进入不同的排序方法或者退出。 排序方法及输出 根据运行者对排序的不同选择,进入排序过程 a.直接插入排序:根据直接排序的算法,输出排序过程 b.折半插入排序:根据折半插入的算法,输出排序过程 c.冒泡排序:根据冒泡排序算法,输出排序过程 d.简单选择排序:根据简单选择排序的算法,输出排序过程 e.快速排序:根据快速排序的算法,输出排序过程 f.堆排序:根

5、据堆排序的算法,输出排序过程 g.归并排序:根据归并排序的算法,输出排序过程4. 程序的主要函数及其伪代码说明 模板类主要说明程序中用到的类的定义templateclass sortlistprivate: int currentsize;/数据表中数据元素的个数public: type *arr;/存储数据元素的向量(排序表) sortlist():currentsize(0)arr=new typemaxsize;/构造函数 sortlist(int n)arr=new typemaxsize;currentsize=n; void insert(int i,type x)arri=x;

6、sortlist()delete arr;/析构函数 void swap(type &x,type &y)/数据元素x和y交换位置 type temp=x;x=y;y=temp; void bubblesort();/冒泡排序 void quicksort(int low,int high);/快速排序 void insertionsort();/直接插入排序 void binaryinsertsort();/折半插入排序 void selectsort();/简单选择排序 void heapsort();/堆排序 void mergesort(sortlist &table);/归并排序 v

7、oid filterdown(const int start);/建立最大堆 void mergepass(sortlist&sourcetable,sortlist&mergedtable,const int len);/一趟归并 void merge(sortlist&sourcetable,sortlist&mergedtable,const int left,const int mid,const int right);/两路归并算法;直接插入排序 直接插入排序的基本思想:开始时把第一个数据元素作为初始的有序序列,然后从第二个数据元素开始依次把数据元素按关键字大小插入到已排序的部分排序

8、表的适当位置。当插入第i(1i=n)个数据元素时,前面的i-1个数据元素已经排好序,这时,用第i个数据元素的关键字与前面的i-1个数据元素的关键字顺序进行比较,找到插入位置后就将第i个数据元素插入。如此进行n-1次插入,就完成了排序。以下是在顺序表上实现的直接插入排序在顺序表上进行直接插入排序时,当插入第i(1i=n)个数据元素时,前面的arr0、arr1、arri-2已经排好序,这时,用arri-1的关键字依次与arri-2,arri-3,的关键字顺序进行比较,如果这些数据元素的关键字大于arri-1的关键字,则将数据元素向后移一个位置,当找到插入位置后就将arri-1插入,就完成了arr0

9、,arr1,arrn-1的排序。伪代码如下template /直接插入排序void sortlist:insertionsort() type temp; int j; for(int i=1;i=0&temparrj) arrj+1=arrj;j-; arrj+1=temp; cout第+num趟排序结果为:; for(int t=0;tcurrentsize;t+) coutarrt ; coutendl; num=0;折半插入排序 折半插入排序的基本思想:设在排序表中有n个数据元素arr0,arr1,arrn-1。其中,arr0,arr1,arrn-1是已经排好序的部分数据元素序列,在插

10、入arri时,利用折半查找方法寻找arri的插入位置。折半插入排序方法只能在顺序表存储结构实现。伪代码如下:template /折半插入排序void sortlist:binaryinsertsort() type temp; int left,right; for(int i=1;icurrentsize;i+) left=0;right=i-1;temp=arri; while(left=right)/找插入位置 int mid=(left+right)/2; if(temp=left;k-)/向后移动 arrk+1=arrk; arrleft=temp; cout第+num趟排序结果为:

11、; for(int t=0;tcurrentsize;t+) coutarrt ; coutendl; num=0;冒泡排序 冒泡排序的基本思想是:设排序表中有n个数据元素。首先对排序表中第一,二个数据元素的关键字arr0和arr1进行比较。如果前者大于后者,则进行交换;然后对第二,三个数据做同样的处理;重复此过程直到处理完最后两个相邻的数据元素。我们称之为一趟冒泡,它将关键字最大的元素移到排序表的最后一个位置,其他数据元素一般也都向排序的最终位置移动。然后进行第二趟排序,对排序表中前n-1个元素进行与上述同样的操作,其结果使整个排序表中关键字次大的数据元素被移到arrn-2的位置。如此最多做

12、n-1趟冒泡就能把所有数据元素排好序。伪代码如下:template /冒泡排序void sortlist: bubblesort() int i=1; int finish=0;/0表示还没有排好序 while(icurrentsize &!finish) finish=1;/排序结束标志置为,假定已经排好序 for(int j=0;jarrj+1)/逆序 swap(arrj,arrj+1);/相邻元素交换位置 finish=0; /排序结束标志置为,表示本趟发生了交换,说明还没有排好序 i+; cout第+num趟排序结果为:; for(int t=0;tcurrentsize;t+) co

13、utarrt ; coutendl; num=0;简单选择排序(直接选择排序) 直接选择排序的算法基本思想是:a)开始时设i的初始值为0。b)如果in-1,在数据元素序列arriarrn-1中,选出具有最小关键字的数据元素arrk;否则算法结束。c)若arrk不是这组数据元素中的第一个数据元素(ik),则将arrk与arri这两数据元素的位置对调;d)令i=i+1转步骤 b)。伪代码如下:template void sortlist:selectsort()/简单选择排序 int k; for(int i=0;i=currentsize-1;i+) k=i; for(int j=i+1;jcu

14、rrentsize;j+) if(arrjarrk) k=j;/k 指示当前序列中最小者的位置 if(k!=i)/最小关键字的数据元素位置不等于i swap(arri,arrk); cout第+num趟排序结果为:; for(int t=0;tcurrentsize;t+) coutarrt ; coutendl; num=0;快速排序 快速排序(Quick Sort)又被称做分区交换排序,这是一种平均性能非常好的排序方法。其算法基本思想是:任取排序表中的某个数据元素(例如取第一个数据元素)作为基准,按照该数据元素的关键字大小,将整个排序表划分为左右两个子表: 左侧子表中所有数据元素的关键字都

15、小于基准数据元素的关键字。右侧子表中所有数据元素的关键字都大于或等于基准数据元素的关键字,基准数据元素则排在这两个子表中间(这也是该数据元素最终应安放的位置),然后分别对这两个子表重复施行上述方法的快速排序,直到所有的子表长度为1,则排序结束。伪代码如下:template /快速排序void sortlist:quicksort(int low,int high)/在待排序区间low,high上,递归地进行快速排序 int i=low,j=high; type temp=arrlow;/取区间第一个位置为基准位置 if(ij) while(ij) while(ij&temparrj)j-; i

16、f(ij)swap(arri,arrj);i+; while(i=arri)i+; if(ij)swap(arri,arrj);j-; arri=temp;/将基准元素就位 cout第+x趟排序结果为:; for(int t=0;tcurrentsize;t+) coutarrt ; coutendl; quicksort(low,i-1);/在左子区间递归进行快速排序 quicksort(i+1,high);/在右子区间递归进行快速排序 堆排序(包括建立最大堆和堆排序两个过程) 堆排序算法的基本思想是:a.对排序表中的数据元素,利用堆的调整算法形成初始堆。b.输出堆顶元素。c.对剩余元素重新

17、调整形成堆。d.重复执行第b、c步,直到所有数据元素被输出。 (1)建立最大堆的伪代码如下:template /建立最大堆void sortlist:filterdown(const int start)/向下调整使从start开始到currentsize-1为止的子表成为最大堆 int i=start,j=2*i+1;/j为i的左孩子 int tablesize=currentsize; type temp=arri; while(j=currentsize-1) if(jcurrentsize-1 & arrj=arrj)break; elsearri=arrj;i=j;j=2*j+1;

18、arri=temp;(2)堆排序如果建立的堆满足最大堆的条件,则堆的第一个数据元素arr0具有最大的关键字,将arr0与arrn-1对调,把具有最大关键字的数据元素交换到最后,再对前面的n-1个数据元素使用堆的调整算法,重新建立最大堆,结果把具有次最大关键字的数据元素又上浮到堆顶,即arr0的位置,再对调arr0和arrn-2,如此反复执行n-1次,最后得到全部排序好的数据元素序列。伪代码如下:template /堆排序void sortlist:heapsort() int tablesize=currentsize; for(int i=(currentsize-2)/2;i=0;i-)

19、filterdown(i); /初始建堆 for(int i=currentsize-1;i=1;i-) swap(arr0,arri);/堆顶元素和最后一个元素交换 currentsize-; filterdown(0);/重建最大堆 cout第+num趟排序结果为:; for(int t=0;ttablesize;t+) coutarrt ; coutendl; num=0; currentsize=tablesize; 归并排序(包括归并算法,一趟归并算法和归并排序)1 归并算法其基本思想是:设有两个有序表A和B,其数据元素个数(表长)分别为n和m,变量i和j分别是表A和表B的当前检测指

20、针;设表C是归并后的新有序表,变量k是它的当前存放指针。开始时i、j、k都分别指向A、B、C三个表的起始位置;然后根据Ai与Bj的关键字的大小,把关键字小的数据元素放到新表Ck中;且相应的检测指针(i或j)和存放指针k增加1.如此循环,当i与j中有一个已经超出表长时,将另一个表中的剩余部分照抄到新表CkCm+n中。下面的归并算法中,两个待归并的有序表首尾相接存放在数组sourcetable.arr中,其中第一个表的下标范围从left到mid,另一个表的下标范围从mid+1到right。前一个表中有mid-left+1个数据元素,后一个表中有right mid个数据元素。归并后得到的新有序表有r

21、ight mid个数据元素。归并后得到的新有序表存放在另一个辅助数组mergedtable.arr中,其下标范围从left到right。伪代码如下:template void sortlist:merge(sortlist&sourcetable,sortlist&mergedtable,const int left,const int mid,const int right) int i=left,j=mid+1,k=left;/指针初始化/i是前一段的当前元素位置,j是后一段的当前元素位置,k是辅助数组的当前位置 while(i=mid&j=right) if(sourcetable.ar

22、ri=sourcetable.arrj) mergedtable.arrk=sourcetable.arri;i+;k+; elsemergedtable.arrk=sourcetable.arrj;j+;k+; if(i=mid) for(int p=k,q=i;q=mid;p+,q+) mergedtable.arrp=sourcetable.arrq;/把前一段复制到mergedtable else for(int p=k,q=j;q=right;p+,q+) mergedtable.arrp=sourcetable.arrq;/把后一段复制到mergedtable2 一趟归并算法设数组

23、sourcetable.arr0到sourcetable.arrn-1中的n个数据元素已经分为一些长度为len的归并项,将这些归并项两两归并,归并成一些长度为2len的归并项,结果放到mergedtable.arr中。如果n不是2len的整数倍,则一趟归并到最后,可能遇到两种情况:剩下一个长度为len的归并项和一个长度不足len的归并项,可用一次merge算法,将它们归并成一个长度小于2len的归并项。只剩下一个归并项,其长度小于或等于len,可将它直接复制到数组mergedtable.arr中。伪代码如下:template template void sortlist:mergepass(s

24、ortlist&sourcetable,sortlist&mergedtable,const int len) int i=0; while(i+2*len=currentsize-1)/表示至少有个子序列 merge(sourcetable,mergedtable,i,i+len-1,i+2*len-1); i+=2*len; if(i+len=currentsize-1)/若只有最后两个子序列 merge(sourcetable,mergedtable,i,i+len-1,currentsize-1); else/若只有最后一个子序列 for(int j=i;j=currentsize-1

25、;j+) mergedtable.arrj=sourcetable.arrj; if(len=currentsize-1) if(numcurrentsize) cout第+num趟排序结果为:; for(int t=0;tcurrentsize;t+) coutmergedtable.arrt ; cout=n,因此在则趟归并中while循环不执行,只做把temptable.arr中的数据元素复制到table.arr的工作。伪代码如下:template void sortlist:mergesort(sortlist &table )/按数据元素关键字非递减的顺序对排序表table中数据元素进行递归排序 sortlist temptable; int len=1; while(lencurrentsize) mergepass(table,temptable,len);len*=2; mergepass(temptable,table,len);len*=2; num=0; 主函数 主要功能是显示主菜单,以及对各种排序的调用伪代码如下:三 上机结果及体会int main()/主函数 /time_t timestart,timeend;double timeused; double timestart,timeend,timeused; int c=1; c

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1