字符串映射成数字,有什么好的算法嘛

2022-03-09 00:07:34 +08:00
 leebs

用 bitmap 存储数据,需要对数据做 offset 映射,有什么好的算法嘛。

4275 次点击
所在节点    程序员
21 条回复
kilasuelika
2022-03-09 00:15:01 +08:00
啥叫 offset 映射
liprais
2022-03-09 00:19:51 +08:00
murmurhash3
CEBBCAT
2022-03-09 03:04:30 +08:00
你……是要做布隆过滤器吗?
murmur
2022-03-09 08:34:31 +08:00
offset 映射是啥意思,记住用户看书看到的地方?
dangyuluo
2022-03-09 08:55:03 +08:00
leebs
2022-03-09 09:12:01 +08:00
@kilasuelika offset 是偏移量,bitmap 里面的概念,相当于数组下标。
leebs
2022-03-09 09:13:12 +08:00
@dangyuluo 任意字符串,不是数字字符串,需要编码成数字。
dangyuluo
2022-03-09 09:15:04 +08:00
那就 md5 然后取前 64bit 做 uint64_t?
gwbw
2022-03-09 09:46:01 +08:00
参考 base64 的算法,映射成 base10 ,用 0~9 表示,这种么;要求纯数字的话可能要 base9 ,留一个数字专门补位
Yi23
2022-03-09 09:49:48 +08:00
如果单纯的字符串转数字的话,是否可以考虑 36 进制( 26 个英文+10 个数字)转换?但这样子可能会导致转出来的数字会非常大
hu8245
2022-03-09 09:51:10 +08:00
面腾讯就问的这个,蹲一个方案💬
X0ray
2022-03-09 09:53:51 +08:00
这?直接 hash 不行吗
also24
2022-03-09 09:56:45 +08:00
直觉上是一个 X-Y Problem

如果是构建布隆过滤器的话,那二进制数据无需转换,直接就能塞进 bitmap ,不需要特殊处理。


如果是想用 bitmap 的下标来表示一个数据的话,那除非特定场景,效率是极低的,基本不存在实际的可行性,用下来还不如直接 hashmap 好用。
labulaka521
2022-03-09 10:06:09 +08:00
@also24 我也觉得是
前提: https://v2ex.com/t/838798#reply14
zhongchaowade
2022-03-09 11:45:34 +08:00
所以需要同时支持正负数,8 ,10 ,16 进制吗?
lniwn
2022-03-09 13:14:04 +08:00
难道在说 ascii 码?
EminemW
2022-03-09 14:15:42 +08:00
hash 然后 mod ?
WhereverYouGo
2022-03-09 14:22:06 +08:00
md5? sha256?
3dwelcome
2022-03-09 14:33:32 +08:00
有个叫 perfect hash 的算法,可以满足楼主的需求。

举个例子,有 10 万个字符串需要查重,那么在 redis 里创建一个大小为 10 万的 bitmap 数据结构,用 0 和 1 来表示,当前字符串是否已被占用。

先对 10 万个字符串做预处理,便可以得到一个不冲突,又刚好完美 1:1 匹配进 bitmap ,自定义 hash 映射表。
littlewing
2022-03-09 14:37:27 +08:00
楼上说 hash 的,冲突怎么解决?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/838982

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX