如何提取给定数字的 p MSB 位
How to extract the p MSB bits of a given number
好的,所以我正在实现一个利用乘法的哈希函数。
我得到了一个K和一个S(其中S = A * 2^单词)。我已经找到了我的 p,我需要做的就是从 KS 的乘积中提取 p 个最重要的位。
因此,假设 KS = 51,它以二进制表示为 110011,p = 4;我需要提取 4 个最重要的位,即 1100 或 12,理论上对于乘法哈希函数来说,这将是 h(k)!
我该怎么做?
一个简单的
int tempHold = k * s;
tempHold << p;
不工作。
您可以对所述数字的对数基数 2 进行地板,以获取数字中的位数 N,然后按 (N -p) 执行右移 (>>)。这将留下 p 个最重要的位。
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 检查输入是否不是整数或数字
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- 如何用数字处理log(0)
- 最高有效数字侧的第N位
- 如何获取一个数字的前3位
- 查找最接近的大于当前数字的数字的索引
- 找到两对数字,使它们的乘积的绝对差最小化
- 我想做一个彼此不同但重复出现的数字
- 将数字转换为字母(例如:123 转换为一二三)
- C++如何计算用户输入的数字中的偶数位数
- 如何在C++中确定文本文件中的元素是字符还是数字
- 打印数字图案
- C++问题:用户认为数字1-100,程序提出问题不超过6次即可得到答案。无法正确
- 如何检查一个c++字符串中有多少相同的字符/数字
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 将数字打印成文字
- 当使用比格式支持的精度更高的精度来显示数字时,会写出什么数据
- 如何提取给定数字的 p MSB 位