nou*_*fal 5 c logic bit-manipulation
这里我想生成一个位模式来设置n等于1从位置开始的数字p.数字来自0 to 31.以下是我的所作所为.
int bitPattern(int n, int p) {
int hex, num1, num2;
hex = 0x80000000;
num1 = (hex >> (31 - p));
num2 = (hex >> (31 - (n+p)));
return num1 ^ num2;
}
Run Code Online (Sandbox Code Playgroud)
例:
bitPattern(6, 2) should return
..000011111100
Run Code Online (Sandbox Code Playgroud)
有少量运营商的替代解决方案?
你可以这样做:
return ((1<<n)-1)<<p;
Run Code Online (Sandbox Code Playgroud)
要使n位置为零,计算(2^n)-1; 回想2^n是1<<n,这样的表达式变为((1<<n)-1).现在你需要p在后面添加零,所以移动结果p.
| 归档时间: |
|
| 查看次数: |
1091 次 |
| 最近记录: |