首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C中的位旋转:如何从2^N转换为N?

C中的位旋转:如何从2^N转换为N?
EN

Stack Overflow用户
提问于 2010-11-13 18:21:57
回答 3查看 274关注 0票数 2

在2^ N,2^(N1)-1到N的范围内,什么是好的位旋转例程?

下面是一些例子:

  • f(1) -> 0
  • f(2-3) -> 1
  • f(4-7) -> 2
  • f(8-15) -> 3

以下是一个实现:

代码语言:javascript
复制
uint f(uint num)
{
    for (uint shifts = 0; num; shifts++) 
        num >>= 1;
    return (shifts - 1);
}
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-11-13 18:23:10

根据数据类型的宽度和可用内存的大小,查找表是一种可能。这几乎肯定是最快的方法。

有关其他方法,请参见http://www-graphics.stanford.edu/~seander/bithacks.html#IntegerLogObvious和后续部分。

票数 4
EN

Stack Overflow用户

发布于 2010-11-13 19:59:06

作为最一般的方法,二进制搜索可能会有所帮助。对于值0..31,它只需要5个阶段。

代码语言:javascript
复制
y = 0;
if(x >= 0x10000<<y) y += 0x10;
if(x >= 0x100<<y) y += 0x08;
if(x >= 0x10<<y) y += 0x04;
if(x >= 0x4<<y) y += 0x02;
if(x >= 0x2<<y) y += 0x01;
票数 3
EN

Stack Overflow用户

发布于 2010-11-13 18:28:20

看看这个页面中计算基数2的对数(或前导零计数,它们是相同的)的黑客:http://www-graphics.stanford.edu/~seander/bithacks.html

您还可以找到用于__builtin_clz的函数x86 (或用于VS的_BitScanReverse )。

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

https://stackoverflow.com/questions/4174030

复制
相关文章

相似问题

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