快速排序实验报告.docx

快速排序实验报告.docx

ID:52176504

大小:141.54 KB

页数:8页

时间:2020-03-23

快速排序实验报告.docx_第1页
快速排序实验报告.docx_第2页
快速排序实验报告.docx_第3页
快速排序实验报告.docx_第4页
快速排序实验报告.docx_第5页
资源描述:

《快速排序实验报告.docx》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、南京邮电大学通达学院实验报告实验名称:快速排序算法课程名称:微型计算机原理与接口技术姓名班级学号:钱煜中14250114250120实验时间:2016.12.2快速排序原理一、实验原理:快速排序算法quicksort主要是利用分治递归的思想进行排序的方法。它的原理是首先从待排序的原始序列a[p,…,r]中选取一个元素a[q]作为分界点(pivot),然后将序列分为两个子序列,左边子序列a[p,…,q-1]元素的值都小于分界点m,右边子序列a[q+1,…,r]元素值都大于分界点的值,此时得到的序列命名为a’,而a[q]应该处于其排

2、好序后的正确位置。然后利用递归的思想,对左右两个子序列a[p,…,q-1]和a[q+1,…,r]再分别进行排序,直到子序列的长度为1结束,序列有序。其中,选取a中的基准分界点的方式有多种,或者选择序列的首元素a[p],或者选择序列的尾元素a[r],或者选择序列中间位置的元素a[(p+r)/2],或者取这三个元素按照大小排序后的中间值。例子:a=[38,81,22,48,13,69,93,14,45,58,79,72],取[(left+right)/2]处的元素作为分界点(pivot)的值。具体第一次分区过程如下:因此,第一次分区

3、,以69为分界点,结果为:a’=[14,58,22,48,13,38,45,69,93,81,79,72]。二、实验代码#includeintfast_sort(int*a,inti,intj,int*p,int**b){intk,temp,f,g;g=*p;g=(12*g)-12;//intf("成功进入快速排序g=%d",g);k=i;i++;for(;ia[k]&&i

4、i);if(i==j)break;if(ia[j]){temp=a[k];a[k]=a[j];a[j]=temp;}//r(f=0;f<12;f++)////intf("%3d",a[f]);////printf("排序成功");for(f=0;f<12;f++){*(b+g+f)=a[f];}returnj;}voiddigui(int*a,inti,intj,int*p,int**b,int*z){intk;if(i

5、tf("成功进入递归p=%d",*p);*p=*p+1;k=fast_sort(a,i,j,p,b);digui(a,i,k-1,p,b,z);digui(a,k+1,j,p,b,z);if(*p>*z)*z=*p;//printf("z=%dp=%d",*z,*p);*p=*p-1;}}voidmain(){inta[]={38,81,22,48,13,69,93,14,45,58,79,72};intb[10][12];inty=0,k,x=0,z=0;printf("初始序列为");for(k=0;k<12;k++

6、){printf("%3d",a[k]);}printf("");digui(a,0,11,&x,b,&z);for(y=1;y

7、4869938145587972进行快速排序,其中,以序列的首元素作为排序的分界点。输出结果要求:输出每一次分区后的结果以及最终排序结果。二、实验总结(问题、解决方法、心得体会等)这次实验我做了很久,重新编写了算法很多次。最开始我对算法的理解不够深,在递归自调用的时候没有想通上下界其实在递归下一层的时候下一层是知道上一层的上下界的,只要排序算法里返还一个最好作为比较值的位置就可以了。一开始排序算法写完就把每次数输出出来,知道后来和同学讨论正确答案是排序了多少次,才想想到我是把每个区排完后的情况,而其实我想输出的是每次排序后数组情

8、况。可是一开始进入的就是左半区的左半区的左半区。。。反正一次是无法输出全部的,因为右半区还没有算。思考了很久,我决定建立一个二维数组,第一行是第一次后的数组,第二行是第二次后的数组。可是如何确定现在是第几次?我建立了一个指针,每次进入递归一层就会+1,每次出递归

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

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

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