[英]Generating particular bit pattern using bitwise operators
在這里,我想生成一個位模式,從位置p
開始設置n
位等於1
數字。 數字從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;
}
例:
bitPattern(6, 2) should return
..000011111100
有更少操作員的替代解決方案嗎?
您可以這樣做:
return ((1<<n)-1)<<p;
要使n
在零位置為1,請計算(2^n)-1
; 回想2^n
為1<<n
,因此表達式變為((1<<n)-1)
。 現在您需要在后面添加p
零,因此將結果向左移動p
。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.