key大概约6百万, 请问使用哪种hash结构?

lidengdeng 2011-12-03 07:36:58
发现使用map结构时, 当记录条数比较多时(key为字符串string型, value为int型), 例如600万, 占的内存量非常大. 32G内存机器根本就不够跑.

请问当记录比较大时, 哪种hash结构比较适合, 对内存需求不是很大? 谢谢
...全文
83 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
lucky-lucky 2011-12-03
  • 打赏
  • 举报
回复
对string做个转换是个不错的想法,可以试一下CRC32
或者采用多级索引,
600万个数据,比如将主键a开头的放在一个map里面,b开头的放在一个map里面,
要的时候先查找第一个字符是什么,如果是a的话那就只加载a所对应的map了
acdbxzyw 2011-12-03
  • 打赏
  • 举报
回复
数据库比较合适
ryfdizuo 2011-12-03
  • 打赏
  • 举报
回复
记错了,是编程之美上的一道题。
ryfdizuo 2011-12-03
  • 打赏
  • 举报
回复
可以把字符串编码成long long。然后就是long long 到int的映射
算法导论上有一种思路是abc => c + b*26 + a*26*26
也可以参考这里:http://topic.csdn.net/u/20110729/10/dbf05cb5-93c5-4e4f-9b23-7772418bb94e.html?12765

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧