位運算技巧

2022-04-30 19:21:12 字數 500 閱讀 3380

1.或

符號:| 

比較兩個數的每一位,只要有乙個數在這一位上為1,所得的新數在這一位上就為1,否則為0。

2.與符號:& 

比較兩個數的每一位,只有兩數這一位同時為1時所得新數為1,否則為0。

3.異或

符號:^ 

比較兩數的每一位,如果一樣所得新數這一位就是0,不一樣就是1。

4.取反

符號:~ 

0變1,1變0。

5.移位

符號:<<,>> 

將二進位制數整體向左/右移動。常用來整除2,乘2。

判斷乙個數的奇偶性

if(x & 1

) 奇數();

else 偶數();

交換兩變數的值

void swap(int a,int

b)

取乙個數的某一位

int

get(int x,int y)

位運算技巧

1.lowbit x 實現 int lowbit int x 這個函式用來求數中二進位制位中最低位的1 完整求法 log2 lowbit x 需要注意的是,答案的範圍是0 30,因為31位是符號位,求出來的值為負數,原因如下 設x 0x8000 0000,那麼設res lowbit x 0x8000...

位運算技巧

數字和1相與 判斷奇偶 x 1 1 奇數 x 1 0 偶數 不用其他空間交換兩值 a a b b a b a a b 或a a b b a b a a b a 0 a a a 0 不用其他空間找陣列中唯一成對的那個數 int b 0 for int i 1 i 10 i int a 10 for i...

位運算技巧

1.n n 1 可以記住結論 n n 1 可以消除n的二進位制形式中的最後乙個1.leet191.位1的個數 public class solution return weight 本題就是利用n n 1 可以消除n的二進位制形式中的最後乙個1,當n為0的時候,說明原來n中的所有1都被消除了。這樣每...