十大内排序算法总结比较
1、最基础排序算法
时间复杂度
稳定性
冒泡排序 O(n^2)
稳定选择排序
O(n^2)不稳定
插入排序 O(n^2)稳定
2、5个中间改良排序算法
时间复杂度稳定性归并排序
O(nlogn)
稳定
希尔排序
平均O(nlogn),最坏O(n^2)
不稳定
堆排序
O(nlogn)
不稳定
快速排序
平均O(nlogn),最坏O(n^2)不稳定
随机化快排
O(nlogn)不稳定
(1)、归并、堆、快排是渐进性的最优排序算法(在大规模的数据下尤为体现);
(2)、解决快排最坏情况的方案:随机化快排,随机选择主元;(与输入无关,就是随机器的概率问题了);
(3)、以上都是比较模型的排序算法,最快时间复杂度为:O(nlogn);
(4)、归并排序用并行算法的话,时间复杂度:O(n/logn);
3、3个局限性的排序算法
时间复杂度稳定性桶排序
O(n)
稳定计数排序
O(n)稳定基数排序
O(n)稳定
(1)、这3个排序算法的时间复杂度都为:O(n),都是稳定性的排序算法;
(2)、都是以空间换时间为代价的算法,处理数据的规模在较小范围内;
(3)、无重复数字出现:建议用桶排;
(4)、有重复数字出现,用计数/基数排序;基数排序是对计数排序的优化,在辅助空间上的优化,基数排序所需辅助空间为:10个该元素空间,计数排序所需辅助空间为:最大数字+1个空间;
4、空间复杂度
O(n):桶排,计数,基数
O(logn):归并,快排,递归堆排
O(1):非递归堆排,希尔
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。