内部排序算法的实现与比较

内部排序算法的实现与比较

ID:11650190

大小:2.66 MB

页数:35页

时间:2018-07-13

内部排序算法的实现与比较_第1页
内部排序算法的实现与比较_第2页
内部排序算法的实现与比较_第3页
内部排序算法的实现与比较_第4页
内部排序算法的实现与比较_第5页
资源描述:

《内部排序算法的实现与比较》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、实验四:内部排序算法的实现与比较一、问题描述1.实验题目:在教科书中,各种内部排序算法的时间复杂度分析结果只给出了算法执行时间的阶,或大致执行时间。试通过随机数据比较各算法的关键字比较次数和关键字移动次数,以取得直观感受。2.基本要求:(1)对常用的内部排序算法进行比较:直接插入排序、简单选择排序、冒泡排序、快速排序、希尔排序、归并排序。(2利用随机函数产生N(N=30000)个随机整数,作为输入数据作比较;比较的指标为关键字参加的比较次数和关键字的移动次数(关键字交换记为3次移动)。(3)对结果作出简要分析。3.测试数据:随机函数产生。二、需求分析1.

2、程序所能达到的基本可能:通过随机数据产生N个随机数,作为输入数据作比较;对常用的内部排序算法:直接插入排序、简单选择排序、冒泡排序、快速排序、希尔排序、归并排序进行比较:比较的指标为关键字参加的比较次数和关键字的移动次数(关键字交换记为3次移动)。最后结果输出各种排序算法的关键字参加的比较次数和关键字的移动次数,并按从小到大排列。2.输入的形式及输入值范围:随机函数产生的N(N=30000)个随机整数。3.输出的形式:输出各种排序算法的关键字参加的比较次数和关键字的移动次数。并按从小到大排列。4.测试数据要求:随机函数产生的N(N=30000)个随机整数

3、。三、概要设计1.所用到得数据结构及其ADT为了实现上述功能,应以一维数组表示集合数据类型。ints[N];intcompare[6]={0},move[6]={0},D[N]={0},RS[N]={0};基本操作:数组赋值:for(i=1;i

4、排序voidInsertSort(intRS[],intn)//直接插入排序intQuickSort(intRS[],intlow,inthigh)//快速排序voidQuickSortprint(intRS[],intn)//输出快速排序后的结果voidShellsert(intRS[],intm,intn)//一趟希尔排序,按间隔m划分子序列voidShellsort(intRS[],intn)//希尔排序voidMerge(intRS[],intlow,intmid,inthigh)//将两个有序序列归并为一个有序序列voidMSort(intRS

5、[],intlow,inthigh)//归并排序2.主程序流程及其模块调用关系voidSelectSort(intRS[],intn)//直接选择排序模块voidBubbleSort(intRS[],intn)//冒泡排序模块voidInsertSort(intRS[],intn)//直接插入排序模块intQuickSort(intRS[],intlow,inthigh)//快速排序模块voidShellsert(intRS[],intm,intn)//一趟希尔排序,按间隔m划分子序列voidShellsort(intRS[],intn)//希尔排序模块

6、voidMerge(intRS[],intlow,intmid,inthigh)//将两个有序序列归并为一个有序序列模块调用四、详细设计1.实现每个操作的伪码,重点语句加注释1)voidcopys(intS[],intRS[],intn)//数组复制{inti;for(i=1;i

7、[0]++;}if(k!=i){RS[0]=RS[k];RS[k]=RS[i];RS[i]=RS[0];move[0]+=3;}}printf("直接选择排序后的结果:");for(i=1;i<=n;i++)printf("%dt",RS[i]);printf("");printf("关键字参加的比较次数:%d,关键字的移动次数:%d",compare[0],move[0]);printf("");}2)冒泡排序voidBubbleSort(intRS[],intn)//冒泡排序{inti,j,flag;for(i=1;i<=n;i++){

8、flag=True;for(j=1;j<=n-i;j++){if(RS[j+1]

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。