2022年结构各种排序算法课程分析方案 .pdf
《2022年结构各种排序算法课程分析方案 .pdf》由会员分享,可在线阅读,更多相关《2022年结构各种排序算法课程分析方案 .pdf(32页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1 / 32 滁 州 学 院课程设计报告课程名称:数据结构设计题目:排序算法实现及比较系别:计算机信息工程学院专业:计算机科学与技术组别:第*组起止日期 : 12 年 5 月 1 日 12 年 6 月 1 日指导教师 :* 计算机与信息工程学院二 一二年制课程设计任务书课程设计题目排序算法实现将比较精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 32 页2 / 32 目录1.引言 3 2.需求分析4 3.详细设计4 3.1 直接插入排序4 3.2 折半排序 4 3.3 希尔排序 5 3.4 简单选择排序6 组长* 学号20* 班级* 系
2、别计算机与信息工程学院专业计算机科学与技术组员* 指导教师* 课程设计目的加深对常见排序算法理解通过程序比较常见算法优越性熟悉加深对数据结构的了解及认识课程设计所需环境Windows xp;VC+6.0 课程设计任务要求实现常见排序算法程序化测试程序比较算法优越性了解常见算法的实际应用课程设计工作进度计划序号起止日期工 作 内 容分工情况1 分析实验类容2 分工3 算法改编成程序4 将子程序合并及调试数据测试及记录5 编写报告指导教师签字:年月日系教研室)审核意见:系教研室)主任签字:年月日精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共
3、 32 页3 / 32 3.5 堆排序 6 3.6 归并排序 7 3.7 冒泡排序 9 4.调试 10 5.调试及检验10 5.1 直接插入排序10 5.2 折半插入排序11 5.3 希尔排序 11 5.4 简单选择排序12 5.5 堆排序 12 5.6 归并排序 13 5.7 冒泡排序 14 6.测试与比较15 6.1 调试步骤 15 6.2 结论 15 7.实验心得与分析15 8.附录 16 8.1 直接插入排序16 8.2 折半插入排序17 8.3 希尔排序 19 8.4 简单选择排序21 8.5 堆排序 23 8.6 归并排序 25 8.7 冒泡排序 28 8.8 主程序 30 1.引
4、言伴随着社会的发展,数据也变得越来越庞大。如何将庞大的数据进行很好的排序,使用户更加方便的查找资料,成了一件越来越重要的问题。对于程序员来说,这将是一个挑战。经常查找资料的朋友都会知道,面对海量的资料,如果其查找的资料没有进行排序,那么其查找资料将会是一件非常痛苦的事情。针对这一问题,我们自此通过一个课程设计来解决它。理论上排序算法有很多种,不过本课程设计只涉及到七种算法。这七种算法共包括:直接插入排序,折半插入排序,希尔排序,简单选择排序,堆排序,归并排序,冒泡排序。本课程设计通过对这七种算法的运行情况进行对比,选择最优秀的算法来提供给用户。希望通过我们的努力能给用户解决一些问题,带来一些方
5、便。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 3 页,共 32 页4 / 32 2.需求分析本课程题目是排序算法的实现,由于各方面的原因,本课程设计一共要设计七种排序算法。这七种算法共包括:直接插入排序,折半插入排序,希尔排序,简单选择排序,堆排序,归并排序,冒泡排序。七种排序各有独到之处,因此我们要通过各种调试分析来比较其优劣长短。为了小组分工的方便,我们特意把子函数写成Header File 文件。这样操作不仅可以使小组分工更加简洁明了,还可以方便子函数的调用,更可以使写主函数时一目了然。为了运行时的方便,我们将七种排序方法进行编号,其中
6、1 为直接插入排序,2 为折半插入排序,3 为希尔排序,4 为简单选择排序,5 为堆排序, 6 为归并排序,7 为冒泡排序。通过这七种选项,可以让用户简单明了的去选择使用哪一种排序方法。本课程就是通过对5 组占用内存大小不同的数据调试来测试这七种算法运行的时间长短,从中选择面对不同大小的文件时,哪一种算法更为快捷。软件环境本课程设计所用操作系统为Windows-XP操作系统,所使用的软件为Microsoft Visual C+ 6.0;3.详细设计3.1 直接插入排序算法思想:直接插入排序是一种最简单的排序方法,它的基本操作是将一个记录插入到一个已排好序的有序表中,从而得到一个新的、记录数增一
7、的有序表。在自i-1 起往前搜索的过程中,可以同时后移记录。整个排序过程为进行n-1 趟插入,即:先将序列中的第一个记录看成是一个有序的子序列,然后从第二个记录起逐个进行插入,直至整个序列变成按关键字非递减有序序列为止。程序实现及核心代码的注释:for (i = 1 。 i for(j=0 。j if(r.basei temp = r.basei。 /保存待插入记录for(i= i 。i j 。 -i r.basei = r.basei-1 。 /记录后移r.basej = temp。 /插入到正确的为位置 r.baser.length =0。3.2折半排序算法思想:由于折半插入排序的基本操作
8、是在一个有序表中进行查找和插入,这个“ 查找 ” 操作可利用折半查找来实现,由此进行的插入排序称之为折半插入排序。折半插入排序所需附加存储空间精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 4 页,共 32 页5 / 32 和直接插入排序相同,从时间上比较,这般插入排序仅减少了关键字间的比较次数,而记录的移动次数 不变。因此,这般插入排序的时间复杂度仍为O / 对顺序表作折半插入排序for ( i = 1 。 i temp=r.basei。 /将 r.basei寄存在 temp 中low=0 。high=i-1 。while( low /在 bas
9、elow 到 keyhigh 中折半查找有序插入的位置 m = (low+high/2 。 /折半if ( temp high = m-1 。 /插入低半区else low = m+1 。 /插入高半区 for( j=i-1 。 j=high+1 。 -j r.basej+1= r.basej 。 /记录后移r.basehigh+1=temp 。 /插入 3.3 希尔排序算法思想:先将整个待排记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录 “ 基本有序 ” 时,再对全体记录进行一次直接插入排序。其中,子序列的构成不是简单的“ 逐段分割 ” ,而是将分隔某个“ 增量 ” 的记
10、录组成一个子序列。程序实现及核心代码的注释:for(k = 0 。 k m = 10 - k。for( i = m 。 i if(r.basei 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 5 页,共 32 页6 / 32 temp = r.basei。 /保存待插记录for(j = i - m 。 j = 0 & temp r.base j + m = r.basej 。 /记录后移,查找插入位置r.base j + m = temp 。 /插入 3.4简单选择排序算法思想:在要排序的一组数中,选出最小的一个数与第一个位置的数交换;然后在剩下
11、的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。程序实现及核心代码的注释:for ( i = 0 。 i /i 为排好序的数的下标,依次往后存放排 /好序的数 temp=r.basei。 /将待放入排好序的数的下标的数保存 for( j = i,m = j +1 。 m / 找出未排序的数中最小的数的循环;if(r.basej r.basem j = m 。r.basei = r.basej 。 /把下标为j 的数与 i 数互换;r.basej = temp。 3.5堆排序算法思想:堆排序只需要一个记录大小的辅助空间,每个待排序的记录仅占有一个存储空间。将序
12、列所存储的元素AN 看做是一棵完全二叉树的存储结构,则堆实质上是满足如下性质的完全二叉树:树中任一非叶结点的元素均不大于(或不小于 其左右孩子 (若存在 结点的元素。算法的平均时间复杂度为 O(NlogN 。程序实现及核心代码的注释:void dp(FILE *fp for(i = r.length / 2 。i = 1 。 -i / 把 r.base1.r.length 建成大顶堆HeapAdjust(r.base,i,r.length 。 for(i = r.length 。i = 2 。 -i temp = r.base1。 r.base1 = r.basei。r.basei = tem
13、p。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 6 页,共 32 页7 / 32 HeapAdjust(r.base,1,i-1 。 /将 r.base1.i-1 重新调整为大顶堆 void HeapAdjust(char *r,int k,int m i=k 。 x=ri 。 j=2*i 。 / 沿 key 较大的孩子节点向下筛选while(j /j为 key 较大的记录的下标 if( (j & (rjrj+1 j+ 。if(xrj / 插入字符比当前的大,交换ri =rj 。i = j 。j *= 2 。 else /否则比较停止。j =
14、m + 1 。 ri = x 。 / 把字符 x 插入到该位置,元素插入实现3.6归并排序算法思想:先将相邻的个数为1 的每两组数据进行排序合并;然后对上次归并所得到的大小为2的组进行相邻归并;如此反复,直到最后并成一组,即排好序的一组数据。程序实现及核心代码的注释:void merge(SqList6 r,int h ,int m ,int w ,SqList6 t / 对相邻两组数据进行组合排序;int i,j,k 。i = h 。j = m + 1 。 /j 为合并的第二组元素的第一个数位置 k =h-1; / k 为存入 t 中的数的位置;while(i &(j / 依次排列两组数据k
15、+。 if(r.basei / 将第一组数据与第二组数据分别比较;精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 7 页,共 32 页8 / 32 t.basek = r.basei+ 。else t.basek = r.basej+ 。 if(i m / 第一组数据先排完的情况while(j t.base+k=r.basej+。else while(i t.base+k=r.basei+。 void tgb(int s,int n,SqList6 r,SqList6 t / 对数据进行每组s个数的归并排序;int i=1 。 /i 为要合并两组元
16、素的第一个数位置;while(i merge(r,i,i+s-1,i+2*s-1,t 。 /i+s-1 为要合并的第一组元素的最后一/数位置、i+2*s-1 为要合并的两组元素/最后一个数位置;i=i+2*s 。 if(i / 考虑 n 不能被 s整除,如果余下的数少于/2*s 但大于s,也就是余下的数不能凑成/两组,凑一组有余,则把余下的数进行组/合,并对其进行排序;merge(r,i,i+s-1,n,t 。else /如果余下的数少于s,则余下的数进行组/合,并进行排序;while(i t.basei=r.basei+ 。 void gb(FILE *fp / 归并主函数; n = r.l
17、ength。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 8 页,共 32 页9 / 32 SqList6 t 。t.base=(char * malloc(r.stacksize*sizeof(char 。 /给待排序的数组t申请内存; while(s / 每组元素不断增加循环进行合并排序; tgb(s,n,r,t。 / s 为每组元素的个数、n 为元素总个数、r /为原数组, t 为待排序的数组,进行归并排s*=2。 / 序;把元素个数相同的两组合并并进行重新 /定义成新的一组,此组元素个数为2*s;if(s tgb(s,n,t,r 。 s
18、*= 2。 /当元素个数小于n 时,对其进行合并排序;else /当元素个数大于n 时,对剩下的数排序; i=0。while(i r.basei=t.basei+1 。i+ 。 3.7冒泡排序算法思想:1、先将一组未排序的数组的最后一个数与倒数第二个数进行比较,并将较小的数放于两个数中较前的位置,然后将比较后的较小的数与倒数第三个进行比较,依次比较到第一个数,即可得到第一个数是所有数中最小的数;2、然后再将数组的最后一个数与倒数第二个数进行比较,并将较小的数放于两个数中较前的位置,依次比较到第二个数,3、如此循环到只剩最后两个比较,即得到排好序的一组数。程序实现及核心代码的注释:for( i=
19、0 。 i / i 为排好序的数的下标,依次往后存放排好序的数; for( j = r.length-2 。j = i 。j - / 从后往前依次两两比较,较小的被调换到前面; if(r.basej+1 / 比较相邻两个数,如果后面的小于前面的,向下执行; 精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 9 页,共 32 页10 / 32 temp = r.basej+1 。 /将后面的较小的数保存起来;r.basej+1 = r.basej 。 /将前面的较大的数放在后面较小的数的位置;r.basej = temp。 /将较小的数放在前面的较大的
20、数的位置; 4.调试检测主函数是否能够稳定运行(如图 4-1:图 4-1 5.调试及检验5.1 直接插入排序输入字符并保存如图 5-1.1):调用算法【 1】处理文件 如图 5-1.2):处理结果 如图 5-1.3):精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 10 页,共 32 页11 / 32 图 5-1.1 图 5-1.2图 5-1.35.2折半插入排序输入字符并保存如图 5-2.1):调用算法【 2】处理文件 如图 5-2.2):处理结果 如图 5-2.3):图 5-2.1 图 5-2.2 图 5-2.3 5.3 希尔排序输入字符并保存
21、如图 5-3.1):调用算法【 3】处理文件 如图 5-3.2):精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 11 页,共 32 页处理结果 如图 5-3.3):图 5-3.1 图 5-3.2图 5-3.3 5.4简单选择排序输入字符并保存如图 5-4.1):调用算法【 4】处理文件 如图 5-4.2):处理结果 如图 5-4.3):图 5-4.1 图图 5-4.3 5.5堆排序精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 12 页,共 32 页13 / 32 输入字符并保存如图 5-5.1):调
22、用算法【 5】处理文件 如图 5-5.2):处理结果 如图 5-5.3):图 5-5.1 图 5-5.2 图 5-5.35.6归并排序输入字符并保存如图 5-6.1):调用算法【 6】处理文件 如图 5-6.2):处理结果 如图 5-6.3):精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 13 页,共 32 页14 / 32 图 5-6.1 图 5-6.2图 5-6.3 5.7冒泡排序输入字符并保存如图 5-7.1):调用算法【 7】处理文件 如图 5-7.2):处理结果 如图 5-7.3):图 5-7.1 图图 5-7.3精选学习资料 - -
23、- - - - - - - 名师归纳总结 - - - - - - -第 14 页,共 32 页15 / 32 6.测试与比较6.1调试步骤在 kcsj 文本文件中随机输入一串字符串,然后保存下来并且复制备份在桌面上。运行程序,调用不算法去处理文件。用秒表计算从开始到结束所用的时间,并记录下来。将文件夹中的kcsj 文本文件删除,将桌面上的备份文件考入文件夹来代替原文件,以保障被操作数据的一致性。用同样的方法依次测试七种算法所用的时间,并记录下来。再将数据依次改变为占用内存大小为50KB 、100KB 、200KB、512KB 、 1024KB 的数字串,重复以上的操作。将记录的数据1m 1.5
24、s 0.2s 6.0s 0.1s 3m 5.5s 1.1s 23s 0.1s 0.1s 24s 200KB - 20s 3.8s - 0.1s 1m 512KB - 1m 14s - 3m 1024KB - 3m 1m - 0.2s 0.3s 10m -:表示时间过长6.2结论通过实验结果的比较与分析我们发现:直接插入排序、冒泡排序、简单选择排序及折半插入排序是低效率的排序方式;所以我们实际编程重要尽可能的避免他们的出现;我们应该用较先进的归并排序及堆排序。7.实验心得与分析通过本次课程设计,我们小组的每个成员都学到了很多东西。首先要说的是我们的编程能力,在这一次的课程设计中我们的编程能力均得
25、到了一定程度的提升。并且通过这次课程设计,我们更加熟悉了如何使用Header File 文件。本次课程设计,让我们对于直接插入排序,折半插入排序,希尔排序,简单选择排序,堆排序,归并排序,冒泡排序等七种排序算法的思想有了进一步的认识,同时对七种算法的应用有了更进一步的掌握。通过这次课程设计,我们对于解决实际问题的能力有了进一步提高。最重要的是,这次课程设计大大的训练了我们的小组团队协作能力。通过这次课程设计我们小组各成员的团队协作能力都有了很大的提升。这种团队协作能力对于我们学编程的来说是精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 15 页,共
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年结构各种排序算法课程分析方案 2022 结构 各种 排序 算法 课程 分析 方案
限制150内