[编程题] 懂二进制
世界上有10种人,一种懂二进制,一种不懂。那么你知道两个int32整数m和n的二进制表达,有多少个位(bit)不同么?
输入例子:
1999 2299
输出例子:
7
class Solution {
public:
/**
* 获得两个整形二进制表达位数不同的数量
*
* @param m 整数m
* @param n 整数n
* @return 整型
*/
int countBitDiff(int m, int n) {
int test = m ^ n;
int cur = 1;
int result = 0;
for (int i = 0; i < 32; ++i) {
if ((test & cur) != 0) {
++result;
}
cur = cur << 1;
}
return result;
}
};
如果写成
if (test & cur != 0)
!= 的优先级大于 &,那么整个判断就是错误的。
如果写成
if ((test & cur) == 1)
也是错误的,因为与运算的结果不一定是 1,可能是其他大于 1 的数!
第二次做,依然犯了第一次做的错误。。
注意 cur 的初始值为 1 而不是 0 !
class Solution {
public:
/**
* 获得两个整形二进制表达位数不同的数量
*
* @param m 整数m
* @param n 整数n
* @return 整型
*/
int countBitDiff(int m, int n) {
int test = m ^ n ;
int cur = 1 ;
int result = 0 ;
for ( int i = 0; i < 32; ++ i ) {
if ( ( test & cur ) != 0 ) ++ result ;
cur = cur << 1 ;
}
return result ;
}
};