答案是使用取模运算或位运算判断奇偶性最常用,前者易读后者高效。通过n % 2 == 0判断余数,或用(n & 1) == 0检测二进制最低位,两种方法均适用于正负整数,推荐根据可读性与性能需求选择。

在C++中判断一个整数是奇数还是偶数是一个基础但常见的编程需求。实现方式有多种,各有特点,适用于不同场景。下面介绍几种常用且有效的方法。
1. 使用取模运算符(%)
最直观的方法是利用取模运算符%来判断数字除以2的余数。
如果余数为0,说明是偶数;否则是奇数。
示例代码:
立即学习“C++免费学习笔记(深入)”;
#include
using namespace std;
bool isEven(int n) {
return n % 2 == 0;
}
int main() {
int num = 7;
if (isEven(num))
cout << num << " 是偶数";
else
cout << num << " 是奇数";
return 0;
}
这种方法逻辑清晰,适合初学者理解,但对负数也有效,因为C++中%的符号与被除数一致。
2. 使用位运算(按位与 &)
整数的奇偶性由其二进制表示的最低位决定:最低位为1是奇数,为0是偶数。
因此可以用&操作检查最低位。
示例代码:
立即学习“C++免费学习笔记(深入)”;
bool isEven(int n) {
return (n & 1) == 0;
}
这种方法效率更高,尤其在性能敏感的场景下推荐使用。它不受正负影响,-3 & 1 结果仍为1,正确判断为奇数。
3. 使用条件判断和减法(不推荐但可行)
通过不断减2直到小于2,再判断剩余值是否为0。
这种方法仅用于教学演示,效率低,不适用于实际项目。
示例逻辑:
bool isEven(int n) {
n = abs(n); // 取绝对值避免负数问题
while (n >= 2) n -= 2;
return n == 0;
}
虽然能工作,但时间复杂度为O(n),远不如前两种方法。
4. 利用除法和乘法验证
一个数如果是偶数,那么(n / 2) * 2 == n成立。
示例:
bool isEven(int n) {
return (n / 2) * 2 == n;
}
这种方法依赖整数除法的截断特性,对负数也适用,但不如位运算高效或直观。
基本上就这些。日常开发中推荐使用取模运算(易读)或位运算(高效),其余方法了解即可。选择哪种方式取决于你对代码可读性和性能的要求。










