- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
让我们从简单开始。假设您想在 long
中找到多少个 1在其二进制表示中。例如,228₁₀ 中有多少个 1?二进制表示为 111001002。我们可以使用 Long.bitCount(228);
返回 4
.
现在,假设我们将两位解释为一个四进制数字(并且最右边的两个位是第一个数字):
00₂ = 0₄
01₂ = 1₄
10₂ = 2₄
11₂ = 3₄
因此,228₁₀ = 11100100₂ = 3210₄。目标是找出二进制表示中有多少非零四进制数字。例如,3210₄ 产生 3,121100₄ 产生 4,000032₄ 产生 2,等等。Long.bitCount(i);
的代码Java文档中的方法由以下给出:
public static int bitCount(long i) {
i = i - ((i >>> 1) & 0x5555555555555555L);
i = (i & 0x3333333333333333L) + ((i >>> 2) & 0x3333333333333333L);
i = (i + (i >>> 4)) & 0x0f0f0f0f0f0f0f0fL;
i = i + (i >>> 8);
i = i + (i >>> 16);
i = i + (i >>> 32);
return (int)i & 0x7f;
}
目标是找出二进制表示中有多少非零四进制数字,没有任何类型的循环,也没有使用
String
s。我正在尝试操作代码,使其适用于四元。这是我目前拥有的:
public static int bitCountQuat(long i) {
i = i - ((i >>> 2) & 0x3333333333333333L);
i = (i & 0x3333333333333333L) + ((i >>> 4) & 0x0f0f0f0f0f0f0f0fL);
i = (i + (i >>> 8)) & 0x00ff00ff00ff00ffL;
i = i + (i >>> 16);
i = i + (i >>> 32);
i = i + (i >>> 64);
return (int) i & 0x7f7f;
}
更多引用:
Efficient Implementation of Hamming Weight .
Binary, desired output, current output
0000, 0, 0
0001, 1, 2
0010, 1, 4
0011, 1, 6
0100, 1, 6
0101, 2, 0
0110, 2, 2
0111, 2, 4
1000, 1, 4
1001, 2, 6
最佳答案
首先将所有非零四进制数字转换为 1s ...
i = (i & 0x5555555555555555L) | ((i >> 1) & 0x5555555555555555L));
...然后计算结果中的位数。
i = (i & 0x3333333333333333L) + ((i >> 2) & 0x3333333333333333L));
i = (i & 0x0f0f0f0f0f0f0f0fL) + ((i >> 4) & 0x0f0f0f0f0f0f0f0fL));
i = (i & 0x00ff00ff00ff00ffL) + ((i >> 8) & 0x00ff00ff00ff00ffL));
i = (i & 0x0000ffff0000ffffL) + ((i >> 16) & 0x0000ffff0000ffffL));
i = (i & 0x00000000ffffffffL) + (i >> 32);
,这是您引用的维基百科文章中提供的实现的后续步骤。
Long.bitCount()
的(整个)实现,甚至
Long.bitCount()
本身用于位计数部分。它的变体比(完整的)维基百科版本的操作要少得多,可以用上述快捷方式版本进行清洗。
关于java - long 中非零四进制(基数为 4)的位数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65262015/
谁能推荐一个好的成员(member)结构? 例如,用户支付了 1 个月的成员(member)费,从 2012 年 2 月 1 日到 2012 年 3 月 1 日结束。 何时何地检查用户是否仍是成员(m
我想在我的 JTextPane 中实现查找机制(如文本编辑器或 word)。我希望它有下一个/上一个选项(向上/向下箭头)并突出显示它找到的所有单词。有没有简单的方法可以做到这一点? 最佳答案 我不是
Android 上是否有任何机制和/或编程实践来执行一次性安装/更新脚本?这似乎是一个非常基本的问题,但谷歌搜索没有帮助。 假设我的应用程序使用了一个数据库,并且需要一个常量值表(例如国家名称、城市名
是否可以将 SimpleMembership 与 ASP.NET WebForms 一起使用? John Galloway 的文章似乎表明 WebForms“在 ASP.NET 成员资格之上实现 OA
我是一名优秀的程序员,十分优秀!