- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在寻找执行 popcount(设置位的计数)的好方法。我在这里找到了这个
http://graphics.stanford.edu/~seander/bithacks.html#CountBitsSetKernighan
unsigned int v; // count the number of bits set in v
unsigned int c; // c accumulates the total bits set in v
for(c = 0; v; c++)
{
v &= v - 1; // clear the least significant bit set
}
试了几个例子,确实有效。二元运算/表示的什么属性使其起作用?
您能否暗示一些关于 popcount 和二进制表示的进一步阅读?
最佳答案
您从一个初始的 v
开始,它最初设置了 n 位。
游戏的重点是在循环的每次迭代中减少 1 位计数。这样,我们可以只计算在到达 n = 0 的点之前所需的循环迭代次数,以计算出初始 n 的值。
请注意,如果 n = 0,则 v = 0,因此循环将在此处停止。但只要 v > 0,我们就会至少运行一次循环体。在每次迭代中,我们最终得到一个少了 1 个位集的 v。
原因如下。我们需要的第一个属性是 v && v == v
。现在 v
是一个位序列(确切的位数取决于您的机器/操作系统),您可以从最高有效位到最低有效位排序。当您递减 v
时,我们可以注意到以下几点:
v
时,所有比 v[k] 更重要的位不会改变。因此,ANDing v
及其减量将保留所有更重要的位,但将 v[k] 设置为 0。根据定义,所有比 v[k] 更不重要的位,即 v[k-1] ... v[0] 已经为 0,因为 v[k] 是“最低有效位,即 1”。因此,在 AND 运算之后,所有较低有效位都将保持为 0。结果是 v && (v - 1)
比 v
包含的设置为 1 的位少一位。
关于binary - 对人口计数算法有所了解,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12678685/
我的网页上有两个 DIV 元素。如果 DIV A 的内部 HTML 是通过不受我控制的第三方脚本添加的,我想删除 DIV B 的内部 html。 在 JS 中实现这一目标的最佳方法是什么? 最佳答案
我整个周末都在看这段代码。我知道有数据,我可以通过其他查询提取它,但 GridView 不会显示和填充。有什么建议吗? string sqlSelection =
所以表格在页面上 然后我使用 AJAX 返回数据 $.ajax({ type: 'POST', url: "ticketAjax.php", data: '&m=swapTi
我有一个表格 View Controller ,我正在使用 Storyboard设计它。原型(prototype)单元非常基本,它只有两个标签。姓名标签和日期标签。 当我运行程序时,样式就在那里(字体
我正在尝试填充不可变 JS 映射。给定一个字段数组和一个表单,例如 {form: 'Register', fields: ['name','firstname']} 我想得到类似的东西: { form
我有两个 Mongoose 模型: 1-事件模型: eventSchema = new mongoose.Schema({ name: { type: String, requir
我想以编程方式填充 WPF ListView 。我认为我接近答案但尚未解决,我使用一种方法来填充 ListView , ListView 在 XAML 中看起来像这样
我有以下场景: 用户可以登录网站。用户可以添加/删除投票(有两个选项的问题)。任何用户都可以通过选择任何选项来对民意调查发表意见。 考虑到上述情况,我有三个模型 - Users Polls Optio
这个问题在这里已经有了答案: Capture __LINE__ and __FILE__ without #define (2 个答案) 关闭 3 年前。 所以我有一个要评估结果的函数,如果结果失败
我有一个使用 innerHTML 在表中添加行的函数: function addRowToTable(tblParam) { var tbl =document.getElementById(tb
我是一名优秀的程序员,十分优秀!