Bit Manipulation
消去二进制中最右侧的那个“1”
二进制中最右侧的那个“1”x & (x - 1) // 消去 x 最后一位的 1,比如 x = 12,那么在二进制下就是 (1100)2
x = 1100
x - 1 = 1011
x & (x - 1) = 1000LintCode: 142. O(1) Check Power of 2
Using
O(1)time to check whether an integernis a power of2.
满足要求的N有两个条件:
N > 0
N 的二进制表示有且只有一个
1
所以用“技巧一”可以写出如下Java代码
public class Solution {
/**
* @param n: An integer
* @return: True or false
*/
public boolean checkPowerOf2(int n) {
// write your code here
return (n > 0) && ((n & (n - 1)) == 0);
}
}LintCode: 365. Count 1 in Binary
Count how many
1in binary representation of a 32-bit integer.
上一道题目的变体咯,既然要看有多少个1,那我就一直算下去,直到它变成0
LintCode: 181. Flip Bits
Determine the number of bits required to flip if you want to convert integer
nto integerm.
Solution 1
Solution 2
Solution 3
巧用异或XOR运算
异或XOR运算LintCode: 82. Single Number
Given
2*n + 1numbers, every numbers occurs twice except one, find it.
XOR Operator
XOR OperatorO(n)TimeO(1)Space
Python collections.Counter()
collections.Counter()O(n)Time at leastO(n)Space
将两个数不同的位设置为“1”,其余为“0”
这一行代码的作用是:找到数字
A和数字B中不相同的一位,并将该位设置为1,其他位设置为0;根据 XOR 的定义,我们知道,在 AXORB 中,为 1 的位即 A 和 B 不相同的位,AXORB 中为 0 的位即 A 和 B 中相同的位所以,要找到A和B中不相同的位,只需要找到在AXORB中从右往左第一个为1的位,保留该位并将其他位置为0即可。
假设数组中两个不同的数字为 A 和 B;
通过遍历整个数组并求整个数组所有数字之间的 XOR,根据 XOR 的特性可以得到最终的结果为
AXORB = A XOR B;通过某种特定的方式,我们可以通过 AXORB 得到在数字 A 和数字 B 的二进制下某一位不相同的位;因为A 和 B 是不相同的,所以他们的二进制数字有且至少有一位是不相同的。我们将这一位设置为 1,并将所有的其他位设置为 0,我们假设我们得到的这个数字为
bitFlag;那么现在,我们很容易知道,数字 A 和 数字 B 中
必然有一个数字与上 bitFlag 为 0;因为bitFlag标志了数字 A 和数字 B 中的某一位不同,那么在数字 A 和 B 中的这一位必然是一个为 0,另一个为 1;而我们在 bitFlag 中将其他位都设置为 0,那么该位为 0 的数字与上 bitFlag 就等于 0,而该位为 1 的数字与上 bitFlag 就等于 bitFlag现在问题就简单了,我们只需要在循环一次数组,将与上
bitFlag为 0 的数字进行XOR运算,与上bitFlag不为 0 的数组进行独立的 XOR 运算。那么最后我们得到的这两个数字就是A和B。
Last updated