免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6830 | 回复: 10
打印 上一主题 下一主题

[算法] 位图数据结构 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-03-09 23:52 |只看该作者 |倒序浏览
10可用积分
在看编程珠玑,看到了一个位图算法...

说:用一个20位长的内存空间可以表示一个所有元素都小于20的简单的非负整数集合。
比如 int a[6] = {1, 2, 3, 5, 8, 13}; 可以用如下方式表示
0 1 1 1 0 1 0 0 1 0 0 0 0 1 0 0 0 0 0 0

请问这是怎么计算出来的啊?

最佳答案

查看完整内容

0 1 1 1 0 1 0 0 1 0 0 0 0 1 0 0 0 0 0 0从最左边0开始数,每一个位加1,看看有什么效果?

论坛徽章:
0
2 [报告]
发表于 2009-03-09 23:52 |只看该作者
0 1 1 1 0 1 0 0 1 0 0 0 0 1 0 0 0 0 0 0
从最左边0开始数,每一个位加1,看看有什么效果?

论坛徽章:
0
3 [报告]
发表于 2009-03-10 00:11 |只看该作者
不知道这样行不行
对于所有小于20的非负整数集合做编号
1 {}
2 {1}
3 {1,2}
...

在20位长的内存空间存着这个编号 根据编号反推集合

论坛徽章:
0
4 [报告]
发表于 2009-03-10 00:14 |只看该作者
或者这样

对空间每个位做编号,分别记为1-20
对于每个位,用0表示存在于集合,用1表示不存在于集合

这样20个位正好能记录20个数

论坛徽章:
0
5 [报告]
发表于 2009-03-10 00:15 |只看该作者
相当于一个只有一位的数组,可以考虑用位域来实现

论坛徽章:
0
6 [报告]
发表于 2009-03-10 00:16 |只看该作者

回复 #2 gawk 的帖子

.....
一开始也是这么想的,但我是从右边往左数的,正好反了!!
呵呵 谢谢啊 脑子进水了

[ 本帖最后由 _mystic 于 2009-3-10 00:17 编辑 ]

论坛徽章:
0
7 [报告]
发表于 2009-03-10 00:18 |只看该作者

回复 #5 皇家救星 的帖子

呵呵 谢谢啊 应该是你说的第二种方法。。。

论坛徽章:
0
8 [报告]
发表于 2009-03-10 00:31 |只看该作者
呵呵 两个人都是正确的答案。这个分数怎么给啊!!!
按先来后到吧。。。
皇家救星 感谢你的热情和帮助!

[ 本帖最后由 _mystic 于 2009-3-10 00:32 编辑 ]

论坛徽章:
0
9 [报告]
发表于 2009-03-10 00:34 |只看该作者
原帖由 _mystic 于 2009-3-10 00:31 发表
呵呵 两个人都是正确的答案。这个分数怎么给啊!!!
按先来后到吧。。。
皇家救星 感谢你的热情和帮助!


感谢回帖的朋友,欣赏LZ的这种美德!

论坛徽章:
0
10 [报告]
发表于 2009-03-10 10:09 |只看该作者
我也看了,位图映射吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP