这是一个program problem from leetcode .它给出一个unsigned int n,要求你返回第'1'位的数字;
int hammingWeight(uint32_t n) {
int num=0;
for(;n!=0;n=n>>1)
{
if(n&1==1)
{
num++;
}
}
return num;
}
这很完美,但是
int hammingWeight(uint32_t n) {
int num=0;
for(;n!=0;n=n>>1)
{
if(1==n&1)
{
num++;
}
}
return num;
}
这个有时行不通!我猜想 1 使用 uint32_t 计算时出现问题,但我无法清楚地理解这一点。
最佳答案
==
的优先级高于 &
。因此,
n&1==1
是n & (1==1)
,而1==n&1
是(1==n) & 1
。
关于c++ - b/w 1==n&1 和 n&1==1 的区别,n 是一个 unsigned int,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31490996/