世界上有10种人,一种懂二进制,一种不懂。那么你知道两个int32整数m和n的二进制表达,有多少个位(bit)不同么?
public int countBitDiff(int m, int n) {
int k = m ^ n;//求出k中1的个数即可
int bit = 1;
int count = 0;
while(bit != 0){
if((bit & k) != 0){//该二进制为1
count++;
}
bit <<= 1;
}
return count;
}