数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx

上传人:p** 文档编号:720783 上传时间:2024-01-23 格式:DOCX 页数:18 大小:114.19KB
下载 相关 举报
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第1页
第1页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第2页
第2页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第3页
第3页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第4页
第4页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第5页
第5页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第6页
第6页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第7页
第7页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第8页
第8页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第9页
第9页 / 共18页
数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx_第10页
第10页 / 共18页
亲,该文档总共18页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx》由会员分享,可在线阅读,更多相关《数据结构:简单选择,直接插入,快速排序,冒泡排序希尔排序,堆排序算法比较平台.docx(18页珍藏版)》请在第壹文秘上搜索。

1、一、试验内容内部排序算法效率比较平台的设计与实现二、试验目的问题描述:各种内部排序算法的时间复杂度分析结果只给出了算法执行时间的阶,或大概执行时间。试通过随机的数据比较几种主要的基本算法的关键字比较次数和关键字移动次数,以取得直观感受。f开始J三、流程图冒泡排序J-N-I简单选择排序直接插入排序开始-2假K=LIenqt1.r.keyuAImFLrW;1.r()=L(l:j=i-2;假1.rGkeyL.r113,真1.foF=L而;1.mTJ=Lr+i结束希尔排序开始k=0假kkfljkLidk.jO&lf0.kpvlr(lk0A1.rj*dk=Lrj.j-d;1.rj*dk=lr(O)i+k

2、结灾快速排序四、源程序代码ftdefineN10intComPare6=0,0,0,0,0,0,Change6=0,0,0,0,0,0;voidinput(ints)(inttestN;srand(unsigned)time(NULL);for(inti=O;iN;i+)testi=rand()%100;for(intj=O;ji;j+)while(testj=testi)(testi=rand()%N;j=O;)for(i=0;i=N-l;i+)si=testi;)voidswap(int&a,int&b)(inttmp;tmp=a;a=b;b=tmp;)voidinsertsort(int

3、s)(inti,j;intaN+l;ai=si-l;)for(i=2;i0&a0aj-l&(+compare0);j-)(aU=O-l;changeO+;)aU=aO;changeO+;)voidbubble_sort(ints,intn)(inti,j,temp,aN;for(i=0;in;i+)(ai=si;)for(j=0;jaj+l)(temp=aj;a11=aU+l;a+l=temp;changel+;)intpartition(intaJntIowJnthigh)(inttzky;t=alow;key=alow;while(lowhigh)(while(low=key)(high-

4、;+compare2;if(lowhigh)(alow=ahigh;low+;change2+;)while(lowhigh&alow=key)(low+;+compare2;)if(lowhigh)(ahigh=alow;high-;change2+;)alow=t;)returnlow;)voidquicksort(intaJntIowJnthigh)intkey;if(lowhigh)(key=partition(a,lowzhigh);quicksort(a,low,key-1);quicksort(a,key+lzhigh);)voidselectsort(intszintn)(in

5、ti,j,k,aN;intt;for(i=0;in;i+)(a=si;)for(i=0;in-l;i+)(j=i;for(k=i+l;k=n-l;k+)(if(akaj&(+compare3)j=k;if(j!=i)t=ai;ai=aU;aj=t;change3+;)voidshellinsertsort(intsJntn)(intizk,aN;k=int(n2);for(i=0;i0;gap/=2)(for(inti=gap;i0&atmpaj-gap;j-=gap)aUl=aU-gap;compare4+;)aj=tmp;change4+;)voidheap_adjust(intarray

6、,inti,intlen)(intrc=arrayi;for(intj=2*i;jlen;j*=2)(if(jIen&arrayj=arrayj)break;)arrayi=arrayj;i=j;)arrayi=rc;)voidheap_sort(intaJntlen)inti;for(i=(len-l)2;i=0;i-)heap_adjust(ajjen);for(i=(Ien-I);i0;i-)(swap(a0,ai);Change5+;弹出最大值,重新对i-1个元素建堆heap-adjust(azOzi-l);)voidCMyDIg-OnButtonlO(/TODO:Addyourcon

7、trolnotificationhandlercodehereUpdateData(TRUE);ints10,a10;input(s);for(inti=O;iN;i+)(ai=si;)CStringstr100;for(i=0;i100;i+)stri=ai;stri.FOrmatr%ij,ai);把整型数组添加到字符串m-shujul+=stri;)insertsort(s);m_zhijiel=compare0;m-zhijie2=change0;quicksort(azOzN-l);m-kuaisul=compare2;m_kuaisu2=change2;selectsort(sfN)

8、;mjiandanl=compare3;mjianda2=change3;SheIIinsertsort(SzN);m-xierl=compare4;m_xier2=change4;heap-sort(azN);m-duil=compare5;m-di2=change5;bubble_sort(s,N);m_maopaol=comparel;m-maopao2=changel;CStringstr2100;for(i=0;i100;i+)str2i=si;for(i=0;iN;i+)(str2i.Format(%iai);把整型数组添加到字符串m-shuju2+=str2i;)UpdateData(FALSE);)五、调试过程对于算法的设计,除了希尔排序和堆排序之外,都比较简单,要注意每种排序的起始位置和哨兵的位置,便可以正确的排出。而希尔排序,尽管是直接插入排序的变形,但应该从中间位置开始,从后至前选择,但是在程序上不好编出。而堆排序,更是难以控制,只好借鉴参考。六、结果分析由随机数产生的10个数,排序后的结果如上图所示,可以发现,快速排序和简单选择排序比较次数和交换次数均较少,适合使用。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > IT计算机 > 数据结构与算法

copyright@ 2008-2023 1wenmi网站版权所有

经营许可证编号:宁ICP备2022001189号-1

本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。第壹文秘仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知第壹文秘网,我们立即给予删除!