首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计算无符号整数中位转换次数的最快方法

计算无符号整数中位转换次数的最快方法
EN

Stack Overflow用户
提问于 2009-01-23 09:17:15
回答 6查看 4.4K关注 0票数 6

我正在寻找计算unsigned int中位跃迁数量的最快方法。

如果整型包含:0b00000000000000000000000000001010

转换次数为:4

如果整型包含:0b00000000000000000000000000001001

转换的次数为:3

语言是C。

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2009-01-23 09:31:07

代码语言:javascript
复制
int numTransitions(int a)
{
  int b = a >> 1; // sign-extending shift properly counts bits at the ends
  int c = a ^ b;  // xor marks bits that are not the same as their neighbors on the left
  return CountBits(c); // count number of set bits in c
}

有关CountBits的有效实现,请参阅http://graphics.stanford.edu/~seander/bithacks.html#CountBitsSetParallel

票数 17
EN

Stack Overflow用户

发布于 2009-01-23 09:29:02

最快取决于您的场景:由于您将数据类型指定为固定大小(无符号整数),因此可以使用查找表。但是,如果只需要执行一次此操作,初始化该表的持续开销太大,而且通过int执行scanning+counting的速度要快得多。

我认为总体上最好的组合是:在表中查找字节或字(256或64k条目不是很多),然后根据字节/字的最后/第一位组合字节/字。

票数 2
EN

Stack Overflow用户

发布于 2009-01-23 09:56:34

在C/C++中,我将执行以下操作:

代码语言:javascript
复制
unsigned int Transitions(unsigned int value)
{
    unsigned int result = 0;

    for (unsigned int markers = value ^ (value >> 1); markers; markers = markers >> 1)
    {
        if (markers & 0x01) result++;
    }

    return result;
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/472325

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档