取模运算与hash function

125 篇文章 8 订阅

取模运算常常对应于hash散列;

k%m

如果从映射(map)的角度看待取模运算的话,其实是对原始空间取值范围的一种放缩,比如缩放到 [0,m1] (整数)。

如果这时 m=2r 的话,也即:

k%2r

如果将 k 也转化为二进制的话,最终映射的值域为对 k 的二进制形式 最后 r 位的截断(可类推至 10r)。
r=2 (保留最后的 2 位):

  • 1 ⇒ 001 ⇒ 01
  • 2 ⇒ 010 ⇒ 10
  • 3 ⇒ 011 ⇒ 11
  • 4 ⇒ 100 ⇒ 00
  • 5 ⇒ 101 ⇒ 01
  • 6 ⇒ 110 ⇒ 10
  • 7 ⇒ 111 ⇒ 11
  • 8 ⇒ 1000 ⇒ 00
  • 9 ⇒ 1001 ⇒ 01

同样这也不是一个好的 m(表示映射过来的slots槽的数量),如果高位不同,只有低位相同的话,不是好的 m ,也就意味着不是好的 hash function;

一个好的选择是选择一个质数(prime)作为 m,最好不接近 2 或 10的整数幂;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

五道口纳什

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值