首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >执行此转换的位Twiddle

执行此转换的位Twiddle
EN

Stack Overflow用户
提问于 2008-10-01 15:26:46
回答 2查看 401关注 0票数 2

我很好奇是否有人对我如何对二进制数做以下操作有一些见解:

转换

代码语言:javascript
复制
   01+0 -> 10+1 (+ as in regular expressions, one or more)
    01 -> 10  
    10 -> 01  

所以,

代码语言:javascript
复制
10101000010100011100
01010100101010100010

为了澄清这不是一个简单的倒置:

代码语言:javascript
复制
000000100000000000
000001010000000000

我在考虑正则表达式,但我正在处理二进制数,并希望保持这种方式。bit twiddling hacks页面也没有给我任何洞察力。这显然具有一些细胞自动机的本质。那么,有谁有一些可以处理这件事的小操作吗?(不需要代码,我知道怎么做)。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2008-10-01 15:36:15

假设x是你的变量。然后你就会有:

代码语言:javascript
复制
unsigned myBitOperation(unsigned x)
{
    return ((x<<1) | (x>>1)) & (~x);
}
票数 11
EN

Stack Overflow用户

发布于 2008-10-01 15:27:56

C/C++中的Twidle是~

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

https://stackoverflow.com/questions/158209

复制
相关文章

相似问题

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