欢迎来到天天文库
浏览记录
ID:43339091
大小:92.50 KB
页数:9页
时间:2019-09-29
《【精品】排序算法的研究》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、前几天应一个朋友的要求,帮他完成了数据排序的一个作业。觉得很冇给大家参考的价值,所以经过他同意,作了些修改帖了上来。源代码见附件,代码中实现了8种排序算法,各算法名称见下表或见源码。运行程序时,将需要你输入一数值,以确泄对多少随机数进行排序。然后将会显示各排序算法的耗时。并且你可选择时否进行止序和反序测试。由于水平有限,可能存在一些错误,还请各位多多指点!通过实验我们可将结果列入下表。以下是VC6.0(Release)+win2000pro+128MDDR+P4(1.6G)因为在多任务操作系统下,系统将进行进程序调度,影响实验结果。以下是经过稍微修止过的值。如果要取得更
2、准确的值,我们得多次实验求其平均值。排序算法实验比较伸位:秒)n方法1K10K100K200K100K正序逆序冒泡排序00.42244.790188.462031.459冒泡排序200.28130.335131.771027.568快速排序000.0160.0475.0957.002直接选择排序00.14116.87879.33216.78533.242堆排序000.0310.1090.0310.015直接插入排序00.0478.70557.800024.865Shell排序000.0470.1100.0150.015归并排序000.0310.0940.0320.032
3、基数排序000.470.1090.0470.046算法与结果联合分析冒泡排序:在最优情况下只需要经过n-1次比较即可得出结果,(这个最优情况那就是序列己是正序,从100K的正序结果可以看出结果正是如此),但在最坏情况下,即倒序(或一个较小值在最后),下沉算法将需要n(n-l)/2次比较。所以-般情况下,特别是在逆序时,它很不理想。它是对数据有序性非常敏感的排序算法。冒泡排序2:它是冒泡排序的改良(一次下沉再一次上浮),最优情况和最坏情况与冒泡排序差不多,但是一般情况下它要好过冒泡排序,它一次下沉,再一次上浮,这样避免了因一个数的逆序,而造成巨大的比较。如(2,3,4,…
4、,n-l,n,1),用冒泡排序需要n(n-l)/2次比较,而此排序只要3轮,共比较(n-l)+(n-2)+(n-3)次,第一轮1将上移一位,第二轮1将移到首位,第三轮将发现无数据交换,序列有序而结束。但它同样是一个对数据有序性非常敏感的排序算法,只适合于数据基本有序的排序。快速排序:它同样是冒泡排序的改进,它通过一次交换能消除多个逆序,这样可以减少逆序时所消耗的扫描和数据交换次数。在最优情况下,它的排序时间复杂度为O(nlog2n)。即每次划分序列时,能均匀分成两个子串。但最差情况下它的时间复杂度将是0(『2)。即每次划分子串时,一串为空,另一串为旷1(程序中的100K
5、正序和逆序就正是这样,如果程序中采用每次取序列中部数据作为划分点,那将在正序和逆时达到最优)。从100K中正序的结果上看“快速排序”会比“冒泡排序”更慢,这主要是“冒泡排序”屮采用了提前结束排序的方法。有的书上这解释“快速排序”,在理论上讲,如果每次能均匀划分序列,它将是最快的排序算法,因此称它作快速排序。虽然很难均匀划分序列,但就平均性能而言,它仍是基于关键字比较的内部排序算法中速度最快者。直接选择排序:简单的选择排序,它的比较次数一定:n(n-l)/2o也因此无论在序列何种情况下,它都不会有优秀的表现(从上100K的正序和反序数据可以发现它耗时相差不多,相差的只是数
6、据移动时间),町见对数据的有序性不敏感。它虽然比较次数多,但它的数据交换量却很少。所以我们将发现它在一般情况下将快于冒泡排序。堆排序:曲于它在直接选择排序的基础上利用了比较结果形成。效率提高很大。它完成排序的总比较次数为O(nlog2n)。它是对数据的有序性不敏感的一种算法。但堆排序将需要做两个步骤:一是建堆,二是排序(调整堆)。所以一般在小规模的序列中不合适,但对于较大的序列,将表现出优越的性能。直接插入排序:简单的插入排序,每次比较后最多移掉一个逆序,因此与冒泡排序的效率相同。但它在速度上还是要高点,这是因为在冒泡排序下是进行值交换,而在插入排序下是值移动,所以直接
7、插入排序将要优于冒泡排序。直接插入法也是…种对数据的有序性非常敏感的一种算法。在有序情况下只需要经过n-l次比较,在最坏情况下,将需要n(n-l)/2次比较。希尔排序:增量的选择将影响希尔排序的效率。但是无论怎样选择增量,最后一定要使增量为1,进行一次直接插入排序。但它相对于直接插入排序,由于在子表中每进行一次比较,就可能移去整个经性表中的多个逆序,从而改善了整个排序性能。希尔排序算是一种基于插入排序的算法,所以对数据有序敏感。归并排序:归并排序是一种非就地排序,将需要与待排序序列一样多的辅助空间。在使用它对两个己有序的序列归并,将有无比
此文档下载收益归作者所有