STL中 __stl_hash_string的问题

wuxiao0313 2009-09-24 04:55:44

struct str_hash{
size_t operator()(const string& str) const
{
unsigned long __h = 0;
for (size_t i = 0 ; i < str.size() ; i ++)
__h = 5*__h + str[i];
return size_t(__h);
}
};


这个实现那个函数的大致代码
请问__h = 5*__h + str[i]; 是什么意思?
为什么用5去乘?
...全文
372 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
wuxiao0313 2009-09-24
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 taodm 的回复:]
因为“统计学结果”。
[/Quote]

什么意思?
wuxiao0313 2009-09-24
  • 打赏
  • 举报
回复
就是hash_map中用到的string哈希函数
taodm 2009-09-24
  • 打赏
  • 举报
回复
因为“统计学结果”。

64,682

社区成员

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

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