一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 2058|回复: 8
收起左侧

[其他] 为什么bucket sort的space complexity是O(kn)

[复制链接] |试试Instant~ |关注本帖
nkbuaayl 发表于 2014-1-16 06:32:21 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
问题不是很复杂,就是bucket sort的time complexity是O(n+k)这个可以理解。但是关于空间的话,为何是O(kn)。比如有1~100的N个整数,如果放到k个Bucket里面,每个bucket如果是一个range的话,N个数是分配到k个bucket里面,如果每个bucket的大小不固定,比如用arraylist,不应该是(n/k)*k=O(n)么,表示不理解。希望大家指点下。
数字媒体技术 发表于 2014-1-16 23:06:31 | 显示全部楼层
弱弱能问一下Bucket Sort的中文名是啥?。。。。
回复 支持 反对

使用道具 举报

readman 发表于 2014-1-16 23:50:01 | 显示全部楼层
刚看下wiki.....我觉得最后的concatenation of buckets[0], ..., buckets[n-1] 导致的吧
回复 支持 反对

使用道具 举报

 楼主| nkbuaayl 发表于 2014-1-17 08:13:00 | 显示全部楼层
回复 支持 反对

使用道具 举报

bb4ever 发表于 2014-1-19 04:33:59 | 显示全部楼层
arraylist插入一个新的元素不一定是常数时间

而如果不用这种“自增长”的数据结果,那么每个bucket都得是长度n的array
回复 支持 反对

使用道具 举报

readman 发表于 2014-1-20 07:54:31 | 显示全部楼层
bb4ever 发表于 2014-1-19 04:33
arraylist插入一个新的元素不一定是常数时间

而如果不用这种“自增长”的数据结果,那么每个bucket都得是 ...

arrayList 每次double它自身的长度
回复 支持 反对

使用道具 举报

bb4ever 发表于 2014-1-20 08:43:26 | 显示全部楼层
readman 发表于 2014-1-20 07:54
arrayList 每次double它自身的长度

再解释一下
插入新的元素如果超过capacity自然要double长度
double完了还要把原array的元素复制到新array当中,这不是常数时间
回复 支持 反对

使用道具 举报

 楼主| nkbuaayl 发表于 2014-1-21 05:55:33 | 显示全部楼层
bb4ever 发表于 2014-1-19 04:33
arraylist插入一个新的元素不一定是常数时间

而如果不用这种“自增长”的数据结果,那么每个bucket都得是 ...

可以理解为worst case每个bucket都要开一个length=n的array,所以是O(nk)。那如果每个Bucket用linkedlist就不需要,在很多情况下可以减少至O(n)么
回复 支持 反对

使用道具 举报

bb4ever 发表于 2014-1-21 06:23:55 | 显示全部楼层
nkbuaayl 发表于 2014-1-21 05:55
可以理解为worst case每个bucket都要开一个length=n的array,所以是O(nk)。那如果每个Bucket用linkedlist ...

虽然用linked list可以把空间代价减少到O(n)。
但是分完bucket之后,每个bucket之中都会有多个元素,你要继续在每个bucket里面进行排序。
就是在linked list上进行排序,时间代价就不像你写的那么美好了。

看问题要有个big picture
时间和空间都是相互关联的,而很多时候大家的目标都是在保持相同的时间代价下提升空间或反过来。
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-6 04:40

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表