经典排序算法——桶排序

补充说明三点

1,桶排序是稳定的

2,桶排序是常见排序里最快的一种,比快排还要快…大多数情况下

3,桶排序非常快,但是同时也非常耗空间,基本上是最耗空间的一种排序算法

无序数组有个要求,就是成员隶属于固定(有限的)的区间,如范围为[0-9](考试分数为1-100等)

例如待排数字[6 2 4 1 5 9]

准备10个空桶,最大数个空桶

[6 2 4 1 5 9]           待排数组

[0 0 0 0 0 0 0 0 0 0]   空桶

[0 1 2 3 4 5 6 7 8 9]   桶编号(实际不存在)

1,顺序从待排数组中取出数字,首先6被取出,然后把6入6号桶,这个过程类似这样:空桶[ 待排数组[ 0 ] ] = 待排数组[ 0 ]

[62 4 1 5 9]           待排数组

[0 0 0 0 0 060 0 0]   空桶

[0 1 2 3 4 567 8 9]   桶编号(实际不存在)

2,顺序从待排数组中取出下一个数字,此时2被取出,将其放入2号桶,是几就放几号桶

[6 24 1 5 9]           待排数组

[0 020 0 0 6 0 0 0]   空桶

[0 123 4 5 6 7 8 9]   桶编号(实际不存在)

3,4,5,6省略,过程一样,全部入桶后变成下边这样

[6 2 41 5 9]           待排数组

[01 2045 60 09]   空桶

[01 2345 6 7 89]   桶编号(实际不存在)

0表示空桶,跳过,顺序取出即可:1 2 4 5 6 9


以下附上用Python实现的桶排序程序

程序


执行结果

推荐阅读更多精彩内容