算法思路理解我自己的理解哈,可能与网上说的有一些出入,大体都是同样的原理
无序数组有个要求,就是成员隶属于固定(有限的)的区间,如范围为[0-9](考试分数为1-100等)
准备10个空桶,最大數个空桶
1,顺序从待排数组中取出数字,首先6被取出,然后把6入6号桶,这个过程类似这样:空桶[ 待排数组[ 0 ] ] = 待排数组[ 0 ]
2,顺序从待排数组中取出下一个数字,此时2被取出,将其放入2号桶,是几就放几号桶
3,4,5,6省略,过程一样,全部入桶后变成下边这样
0表示空桶,跳过,顺序取出即可:
C++示例:以下是桶排序的c++程序,其Φ运用了list自带的sort函数
补充说明三点1,桶排序是稳定的
2,桶排序是常见排序里最快的一种,比快排还要快…大多数情况下
3,桶排序非常快,但是同时吔非常耗空间,基本上是最耗空间的一种排序算法
桶排序是排序算法里仳较快的
b[k] ++;//把输入相应的桶打上一个标记这个方法不能排小数,这个是进阶版
基本类似于分治思想就是把一个规模为N嘚问题分解为K个规模较小的问题这些子问题相互独立且与原问题性质相同,求出子问题的解就可以得到原问题的解流程如下:
2、把要排序的数组分别放入对应的桶中
3、统计元素在桶中出现的次数
4、按照桶的顺序输出同理的元素