码迷,mamicode.com
首页 > 编程语言 > 详细

算法:桶排序

时间:2017-06-23 18:25:43      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:范围   bucket   创建   turn   str   选择   个数   []   max   

通排序非常浪费空间, 比如需要排序的范围在0~2000之间, 需要排序的数是[3,9,4,2000], 同样需要2001个空间

注意: 通排序不能排序小数

 

def bucketSort(nums):
# 选择一个最大的数
max_num = max(nums)
# 创建一个元素全是0的列表, 当做桶
bucket = [0]*(max_num+1)
# 把所有元素放入桶中, 即把对应元素个数加一
for i in nums:
bucket[i] += 1

# 存储排序好的元素
sort_nums = []
# 取出桶中的元素
for j in range(len(bucket)):
if bucket[j] != 0:
for y in range(bucket[j]):
sort_nums.append(j)

return sort_nums

nums = [5,6,3,1,65,2]
print(bucketSort(nums))
x

算法:桶排序

标签:范围   bucket   创建   turn   str   选择   个数   []   max   

原文地址:http://www.cnblogs.com/aomi/p/7071048.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!