题解 | 两个整数二进制位不同个数
两个整数二进制位不同个数
https://www.nowcoder.com/practice/16e48900851646c0b2c6cdef9d7ea051
#include <stdio.h>
int main() {
int a, b;
while (scanf("%d %d", &a, &b) != EOF) { // 注意 while 处理多个 case
int count = 0;
for (int i = 0; i <= 31; i++) {
// 修正运算符优先级,确保比较的是提取出来的位值
if (((a >> i) & 1) != ((b >> i) & 1)) {
count++;
}
}
// 修正逻辑错误,打印计算出来的不同位的数量 count
printf("%d\n", count);
}
return 0;
}


