欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

    七种排序算法的比较及每种排序的上机统计时间.docx

    • 资源ID:4929832       资源大小:635.88KB        全文页数:34页
    • 资源格式: DOCX        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    七种排序算法的比较及每种排序的上机统计时间.docx

    数据结构课程设计报告课题:排序算法的比较学院:信息学院班级:2011级电子信息工程1班小组成员:韦志东(组长)20111601310027夏琪20111601310028完成时间:2014-01-08教师:周铁目录1.3、设计任务书27271、课程分析11、选题要求利用随机函数产生30000个随机整数,利用直接插入排序、希尔排序,冒泡 排序、直接选择排序、快速排序、堆排序、归并排序的排序方法进行排序,并统 计每一种排序上机所花费的时间。1.2、选题的意义及背景排序是计算机程序设计中的一种重要操作,它的功能是将一个数据元素的任 意序列,重新排列成一个按关键词有序的序列。此实验通过对各种内部排序算法进行比较,能使我们更好的掌握各种排序的 基本思想,掌握各种排序方法的算法实现,掌握各种排序方法的优劣分析及花费 的时间的计算,掌握各种排序方法所适应的不同场合。通过该题目的设计,可以 加深理解各种数据结构的逻辑结构、存储结构及相应上运算的实现,进一步理解 和熟练掌握课本中所学的各种数据结构,学会如何把学到的知识用于解决实际问 题,培养我们的动手能力。1.3、设计任务书(1)定义结构体,头文件,定义数组范围,大小。(2)依次描写七种排序的算法。(3)描写产生随机函数的算法。(4)描写菜单函数。(5)描写主函数,调用七种排序的算法。2、设计分析2.1原始资料用户输入记录的个数30000个,数据由随机函数生成。2.2输出数据产生的随机数分别用冒泡排序、直插排序、希尔排序、选择排序、快速排序、 堆排序、归并排序这些排序方法进行排序,并统计每一种排序上机所花费的时间。3 .程序源代码及其注释#include "stdio.h” #include "stdlib.h” #include "math.h” #include<time.h> #include<conio.h>#defineMAX 60000 /*记录数组的个数*/#defineNUM 30000 /*实际输入数组的个数*/typedefint datatype;typedefstruct /*定义记录为结构体类型*/ int key;/*记录的关键词域*/datatype other; /*记录的其它域*/ rectype;rectype *s1,sMAX;/*sMAX存放原始随机数,*s1取出原始数据后进行排序*/*直接插入排序算法如下*/void insert_sort(rectype *r) /*对数组r按递增顺序进行插入排序算法*/ int i,j,n=NUM;/*NUM为实际输入的记录数,是一个常量*/for(i=1;i<=n;i+)/* i<NUM条件很重要,NUM为实际记录数*/ r0=ri;/*r0为监视哨*/j=i-1;/*依次插入记录r1,,rNUM*/while(r0.key<rj.key) /*查找 ri合适的位置 */rj+1=rj-;/*将记录关键词大于ri.key的记录后移*/rj+1=r0;/*将记录ri插入到有序表的合适的位置上*/*INSERTSORT*/*希尔排序算法如下*/ int i,n,jump,change,temp,m; /*change为交换标志,jump为增量步长*/jump=NUM; n=NUM; /*NUM为顺序表的实际长度*/while(jump>0) jump=jump/2; /*取步长 d(i+1) = d(i)/2*/do change=0; /*设置交换标志,change=0表示未交换*/for(i=1;i<=n-jump;i+) m=i+jump; /*取本趟的增量*/if(ri.key>rm.key) /*记录交换*/ temp=rm.key;rm.key=ri.key;ri.key=temp;change=1; /*change=1 表示有交换 */*if*/*for*/ /*本趟排序完成*/while(change=1); /* 当 change=0 时终止本趟排序*/*while*/* 当增量 jump=1 且 change=0 时终止算法 */*SHELLSORT*/*冒泡排序算法如下*/void bubble_sort(rectype *r) /*从下往上扫描的冒泡排序*/ int i,j,noswap=0,n=NUM;/*noswap为交换标志,NUM为实际输入记录数*/rectype temp;for(i=1;i<n;i+)/* 进行 nT 趟冒泡排序 */ noswap=1;/*设置交换标志,noswap=1表示没有记录交换*/for(j=n;j>=i;j-)/* 从下往上扫描*/if(rj.key<rj-1.key)/* 交换记录*/ temp.key=rj-1.key;rj-1.key=rj.key;rj.key=temp.key;noswap=0; /*当交换记录时,将交换标志置0即noswap=0 */*if*/if(noswap) break; /*若本趟排序中未发生记录交换,则终止排序*/*for*/*终止排序算法*/*BUBBLESORT*/*快速排序算法如下*/int partition(rectype *r,int s,int t) /*快速排序算法中的一趟划分函数*/ int i,j;rectype temp;i=s;j=t;temp=ri;/*初始化,temp为基准记录*/do while(rj.key>=temp.key)&&(i<j)j-;/*从右往左扫描,查找第一个关键词小于temp的记录*/if(i<j) ri+=rj; /*交换 ri和 rj*/while(ri.key<=temp.key)&&(i<j)i+;/*从左往右扫描,查找第一个关键词大于temp的记录*/if(i<j) rj-=ri; /*交换 ri和 rj*/while(i!=j);/*i=j,z则一次划分结束,基准记录达到其最终位置*/ri=temp; /*最后将基准记录tem p定位*/return(i);/*PARTITION*/void quick_sort(rectype *r,int hs,int ht)/*对 rhs到 rht 进行快速排序 */ int i;if(hs<ht) /*只有一个记录或无记录时无需排序*/ i=partition(r,hs,ht); /*对 rhs到 rht 进行一次划分 */quick_sort(r,hs,i-1); /*递归处理左区间*/quick_sort(r,i+1,ht); /*递归处理右区间*/ /*QUICK_SORT*/*直接选择排序算法如下*/void select_sort(rectype *r) rectype temp;int i,j,k,n=NUM; /*NUM为实际输入记录数*/for(i=1;i<=n;i+)/*做n-1 趟选择排序 */ k=i;for(j=i+1;j<=n;j+)/*在当前无序区中选择关键词最小的记录rk*/ if(rj.key<rk.key) k=j;if(k!=i) temp=ri;/* 交换记录 ri和 rk*/ri=rk;rk=temp;/*for*/*SELECT_SORT*/*堆排序算法如下*/void shift(rectype *r,int i,int m)/*堆的筛选算法,在数组中ri到rm中,调整堆 ri*/ int j; rectype temp;temp=ri; j=2*i;while (j<=m)/*j<=m,r2*i是ri的左孩子*/ if(j<m)&&(rj.key<rj+1.key)j+; /*j指向ri的左右孩子中关键词较大者*/if(temp.key<rj.key) /*若孩子结点的关键词大于父结点*/ri=rj;/*将rj调到父亲结点的位置上*/i=j;/*调整i和j的值,以便继续“筛”结点*/j=2*i;elsej=m+2;/*调整完毕,退出循环*/ri=temp;/*将被筛选的结点放入正确的位置*/*SHIFT*/void heap_sort(rectype *r)/*对数组 r1到 rNUM 进行堆排序 */ rectype temp;int i,n;n=NUM;/*NUM为数组的实际长度*/for(i=n/2;i>0;i-)/*建 立初始堆*/shift(r,i,n);for(i=n;i>1;i-)/*进行n-1趟筛选,交换,调整,完成堆排序*/ temp=r1;/*将堆顶元素r1与最后一个元素交换位置*/r1=ri;ri=temp;shift(r,1,i-1);/*将数组元素r1到ri-1重新调整成为一个新堆*/ /*FOR*/*HEAP_SORT*/*二路归并排序算法如下*/void merge(rectype *a,rectype *r,int low,int mid,int high) int i,j,k;i=low;j=mid+1;k=low;while(i<=mid)&&(j<=high)/*将两个相邻有序子表进行合并*/ if(ai.key<=aj.key)/*取 两表中小者复制*/rk+=ai+;else rk+=aj+;while(i<=mid) rk+=ai+;/*复制第一个有序子表的剩余记录*/ while(j<=high) rk+=aj+;/*复制第二个有序子表的剩余记录*/ /*MERGE*/void merge_pass(rectype *r,rectype *r1,int length) int i=1,j,n=NUM;while (i+2*length-1)<=n)/*归并若干长度为2*length的两个相邻有序子表*/ merge(r,r1,i,i+length-1,i+2*length-1);i=i+2*length;/*i指向下一对有序子表的起点*/if(i+length-1<n)merge(r,r1,i,i+length-1,n);/*处理表长不足 2*length 的部分 */else for(j=i;j<=n;j+)r1j=rj;/*将最后一个子表复制到口中*/*MERGEPASS*/void merge_sort(rectype *r) int length;rectype r1MAX;length=1;/*归并长度从1开始*/while(length<NUM) merge_pass(r,r1,length);/*一趟归并,结果存放在口中*/length=2*length;/*归并后有序表的长度加倍*/merge_pass(r1,r,length);/*再次归并,结果存放在匕中*/length=2*length;/*再次将归并后有序表的长度加倍*/*MERGE_SORT*/void creat_randnum(int *a )/*产生给定个数和范围的随机整数函数*/ int i;int range=30000;srand(time(NULL);for(i=1;i<=NUM;i+)ai=rand(); /*调用rand生成随机整数*/printf("nnttt排序前的原始随机整数为:nnt");for(i=1;i<=NUM;i+) printf("%6d”,ai); /*输出随机整数 */if(i%10=0) printf("nt");printf(n);/*CREAT_RANDNUM*/void create() /*产生NUM个随机整数并保存到记录数组、中*/ int bMAX;int range=30000,i;creat_randnum(b); /*调用随机整数生成函数,结果存放在数组b中*/for(i=1;i<=NUM;i+)si.key=bi;/*将随机整数存放到数组、中*/s1=s;/*s1指向s,以便保存原始数据*/*CREAT*/void print_record(rectype *r)/*记录数组的输出函数 */ int i;printf("nttt排序后的有序随机整数:nnt");for(i=1;i<=NUM;i+)printf("%6d”,ri.key);if(i%10=0) printf("nnt");getchar();getchar();/*PRINTRECORD*/int menu_select()/*主 菜单选择模块 */ char c; int kk;system("cls");/*清 屏函数 */printf("内排序算法的比较主控模块:nn");printf("ttt1.直接插入排序n");printf("ttt2.printf("ttt3.printf("ttt4.printf("ttt5.printf("ttt6.printf("ttt7.printf("ttt0.希尔排序n);冒泡排序n");快速排序n);直接选择排序n);堆排序n");二路归并排序n");退出n");do printf("nttt请按数位07键选择功能:");c=getchar(); kk=c-48;while (kk<0)|(kk)>7);return(kk);/*MENU_SELECT*/main() /*算法比较一主程序模块*/double time1, time2, time3, time4, time5, time6, time7;clock_t start, finish;int kk;do kk=menu_select(); /*进入主菜单选择模块*/if(kk!=0) create();/*建立记录数组 */switch(kk) case 1: start=clock();insert_sort(s1);finish=clock();Jbreak;time1 = (double)(finish - start)/ CLOCKS_PER_SECprintf("直接插入排序耗时%三secondsn”, time1);case 2: start=clock();shell_sort(s1);finish=clock();time2 =(double)(finish - start)/ CLOCKS_PER_SECprintf("希尔排序耗时%三 secondsn”, time2); break;case 3: start=clock();bubble_sort(s1);finish=clock();time3 = (double)(finish - start)/ CLOCKS_PER_SEC ;printf("冒泡排序耗时%三 secondsn”, time3); break;case 4: start=clock();quick_sort(s1,1,NUM);finish=clock();time4 = (double)(finish - start)/ CLOCKS_PER_SEC ;printf("快速排序耗时%三 secondsn”, time4); break;case 5: start=clock();select_sort(s1);finish=clock();time5 = (double)(finish - start)/ CLOCKS_PER_SEC ;printf("直接选择排序耗时%三 secondsn”, time5); break;case 6: start=clock();heap_sort(s1);finish=clock();time6 = (double)(finish - start)/ CLOCKS_PER_SEC ;printf("堆排序耗时 %f secondsn”, time6); break;case 7: start=clock();merge_sort(s1);finish=clock();time7 = (double)(finish - start)/ CLOCKS_PER_SEC ;printf("二路归并排序耗时 %f secondsn”, time7); break;case 0:exit(0);print_record(s1);while (kk!=0);/*MAIN*/4 .测试结果主控模块:1=1 回内排序算法的比较入序序序择并 插排排排选序归 接尔泡速接排路出 直希冒快直垠二退 12345670请按数字。一了键选择功能:选择直接插入排序:内排序算法的比较请按数字。一了键选择功能:1排序前的原始随机整数为: , DAC'b'Debug'gg 旧 xb入序序序择并 插排排排选序归 接尔泡速接排路出 直希冒快直堆二退 123456701889 24052 25174 117728039 5557 2943 5623 14804 18132 25443 19380 249110169 9518 22121 24859 25231 19628 12G55 1345 15722 24250 27032 18707 31649 4014 4916 3300 20151 1557G 20801 909 7622 27763 2110 13650 1H000 9686 20133 16880 26740 2301 10058 32194 28270 7129 309175588 221 GG 5025 10736 23879 224 21150 G10 6884 3159G 29733 12815 9450 14473 27758 22431 19474 25642 7695 51046060 10782 30891 11348 22784 11092 30747 6089 10010 19941 8078 5319 5245 4639 425 22033 32016 29907 30257 8616 7195 182G0 32489 29847 3114 3111 24534 20577 22047 16451 1652。 14744 21045 523424441 30435 26054 1471 166412093 7611 140304517 27659 18547 16029 15618 12879 8891 17152 25399311364094 19357 20188 29803 267009205 2828H 8110 1856 19467 113914357 10729 11763 3052 20631 15253 21830 3000 3735 28019 31835 13316 29648 9402 9295 7056 9716 5865 206明3095 15983 29215 10347 27928 20999 13981 10857 27227 25743 9513 10254 13959 1289 1207 7523 6157 141348579 11396排序前本有30000个随机数显示,但数据太多,只截一部分图来表示。排序后也一样,应有30000个排好顺序的整数显示,但由于数据过多,也只截一部分图来表示。(2)选择希尔排序:排序前本有30000个随机数显示,但数据太多,只截一部分图来表示。排序后也一样,应有30000个排好顺序的整数显示,但由于数据过多,也只截一 部分图来表示。由图可知,希尔排序耗时0026000秒* D:CbDebuggg.exe'内排序算法的比较一一主控模块:序kF君入序序序择并插排排排选序归序 序- - - -希冒快直堆二退2 3 4 5 G 7 0请按数字。一了键选择功能: 请按数字。一了键选择功能:2 排序前的原始随机整数为:3561 13860 4440 8160 9456 4662 321 65 2H80 20962 15311 22293 2明26 1385 11861 26066 32212339194129039 9918 17417902 120472112 31198 23399436。25034 12054 26797 17724 1003431947 32254 5762 3265 23927 3392 15829 30324 23311 2564165场 27717 8325 22095 14379 14637 1038 8686 19986 16596 16423 505 171 26 1932 30080 11829 17747 7504 30788 12380 8781 116991147426733742 12413 4537 11G134149 17755 204314682 30903 8938 180693722 30GG5 84308777 27231 1848 17224 26384 29431177 27676 22769 4557 26190 26973 3555 28527 26014 9287 12384 31456 24286 5438 9237 23945 7221 32000 30350 30894 17014 27627 18536 228174975 217136931 625 764 12615 9307 29GO0 24624 2509 12057 6592 19113 3966 12793 15066 7550 241611504488861825216G329241225G53081230757235512549831163236142709116326269203118265 13935 5160 15533 32385 321G7 195G7 13649 29096 13391 31855 25600 24263 291458426 30196(3)选择冒泡排序:排序前本有30000个随机数显示,但数据太多,只截一部分图来表示。排序后也一样,应有30000个排好顺序的整数显示,但由于数据过多,也只截一 部分图来表示。 ' D:CbDebuggg.exe'1内排序算法的比较-主控模块:序kF君入序序序择并插排排排选序归序 序- - - -希冒快直堆二退2 3 4 5 G 7 0请按数字。一了键选择功能: 请按数字。一了键选择功能:3排序前的原始随机整数为:4234 16159 29506 3763 24542580G 12434 21827 73122953643851214321 8明31358 1877 297929338 1886 19617 5944 1G4G7 5804 18945 21291 161685086 26793 20978 13916 23887 209GG 2522G9182 5343 18624 222417129 8049 22330 12H3S 26773 29094 29882 227598294 19825 7676 25944194599357 232016315 24577 1395 5672 11610 19618 25586 13177 24826 1930310934 12109 275186356 19507 30066 27562 19852 46 26855 26801 943 19919 15767 30875 646。 25497 28汹 257231252 27166 18965 6540 23636 1G553 14352 022 26710 25319 16032 19995 25759 311824437 1774030957 18170 22935 2938 22898 2145 1816 1471 17064 1146。 17933 13477 162557104 583 4348265明 27901 19651 1289G 5795 1072 2775G 16331 27086 28721 5659 22355 9404 21164 29407 1204G8559 25566 28759 146G8 283243219 27996 25827 9532 1985784792582 19615 14422 19195950819715 10353 101797326 28758 250GG7994 17618 9925 241701 74012134 252381530 10353 5870FD选择快速排序:排序前本有30000个随机数显示,但数据太多,只截一部分图来表示。排序后也一样,应有30000个排好顺序的整数显示,但由于数据过多,也只截一 部分图来表示。请按数字。一了键选择功能: 请按数字。一了键选择功能:4内排序算法的比较主控模块:序 序序 入序序序择并 插排排排选序归 接尔泡速接排路出 直希冒快直垠二退 1234567049072805419186 285341238 209581676213310207531165184582755911199 100293572 271Q148852240994786771218043019431487 2641623623 33142158457702292515199321331969845Q 288Q29942 2862343813177767331886282213119423099 327322398 2088937912283274072513214182370712706 228421248 36751311353111664117965254712584429831 2698716794 28526291793Q88725179291891917477032732Q 212893078 1313637093015220898215862643Q11383Q234 915714224 306523778934628281235221Q9921954132548 65762388 13313247931808214216218119245164582Q456 86Q6630 58741885224973185622947386016922178Q1 938120043 1301732095797614318114369454157798263 781727620 15194139736014375326213180862Q97817556 948714504 106924158272611721366831045524208973 1543626583 15627289601849632120122812359676504482 1Q56929483 2619419751327003147314311排序前的原始随机整数为:选择直接选择排序:排序前本有30000个随机数显示,但数据太多,只截一部分图来表示。排序后也一样,应有30000个排好顺序的整数显示,但由于数据过多,也只截一 部分图来表示。由图可知,直接选择排序耗时1528000秒* D:CbDebuggg.exe,内排序算法的比较-一主控模块:1.直接插入排序2.希尔排序3.冒泡排序4.快速排序5. 直接选择排序6. 堆排序7.二路归并排序0.退出请按数字。一了键选择功能: 请按数字。一了键选择功能:5排序前的原始随机整数为:572661601387763451525235271155532228177162809614102584730265162Q32452Q81718761268521Q23713223351216517318881760718953265562884512399802320Q4231706316443173229QQ13744238762491165201Q12639111666721460147211117213741226321821Q271126566213492244720717171071752510495124802568126701170883094723541247052022816Q532839434852354820941474820337273941198322229810828893283775501502111073303981472919Q932856627738772185932226644331358522312752967723QQ759Q2215068145921447512595291351611116Q3637052599212899938857451170138082878Q3787133329913154181346823865145361 7877811211916368225744287055521137061Q9313127213420111091385425652224362799297432744931015509923782167152983877122695114955206431965018688152651692856796988826719386296601205524848Q302Q11Q36831968894033143722762293831868822933128053234531719290081786828001选择堆排序:排序前本有30000个随机数显示,但数据太多,只截一部分图来表示。排序后也一样,应有30000个排好顺序的整数显示,但由于数据过多,也只截一部分图来表示。由图可知,堆排序耗时0.008000秒 'D:CbDebuggg.exe排序算法的比较-主控模块:1. 直接插入排序2. 希尔排序3. 冒泡排序4. 快速排序5. 直接选择排序6. 堆排序7. 二路归并排序0.退出请按数字。一了键选择功能: 请按数字。一了键选择功能:6排序前的原始随机整数为:6125674630618257181471911068308262780514316952882511221114642142423713614413756137374209324171994846482868921420310443223970482358414748166524606216542738221004412626138135684460117102386513793228643245022363189931368715165

    注意事项

    本文(七种排序算法的比较及每种排序的上机统计时间.docx)为本站会员(小飞机)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开