几种常见的排序算法对比

来源:互联网 发布:什么值得买app源码 编辑:程序博客网 时间:2024/05/16 08:11

排序                         

平均时间                                  

最差                                              

                            

额外                                         

备注

冒泡

 O(n 2 )

O(n 2 )

  稳定

O(1)

n 小时较好

交换

  O(n 2 )

O(n 2 )

不稳定

O(1)

n 小时较好

选择

 O(n 2 )

O(n 2 )

不稳定

O(1)

n 小时较好

插入

 O(n 2 )

O(n 2 )

稳定

O(1)

大部分已排序时较好

基数

O(log RB)

O(log R B)

稳定

O(n)

B 是真数 (0-9) 

R 是基数 ( 个十百)

Shell

O(nlogn)

O(n s ) 1<s<2

不稳定

O(1)

s 是所选分组

快速

O(nlogn)

O(n 2 )

不稳定

O(nlogn)

n 大时较好

归并

O(nlogn)

O(nlogn)

稳定

O(1)

n 大时较好

O(nlogn)

O(nlogn)

不稳定

O(1)

n 大时较好

稳定的排序:冒泡,插入,基数,归并 
0 0