题解 | 两个整数二进制位不同个数
两个整数二进制位不同个数
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; }