题目出处:洛谷P2955 ,略有改编。
题目描述
给你 (N(1 le N le 1000)) 个数,你需要判断每个数是奇数还是偶数。
输入格式
输入的第一行包含一个整数 (N(1 le N le 1000)) 。
接下来 (N) 行每行包含一个整数 (a(1 le a le 10^{1000})) 。
输出格式
对于每一个输入的 (a) ,你需要判断它是奇数还是偶数。如果 (a) 是奇数,输出 "odd" ;否则,输出 "even" 。
样例输入
2
1024
5931
样例输出
even
odd
问题分析
这道题目很简单,就是判断奇数或者偶数。
但是有一个问题是:每个数的范围比较大,达到了 (10^{1000}) 数量级。
所以用 int 或者 long long 都是无法存储的。
所以我们可以想到用字符串来表示每一个数,然后获取字符串的最后一个字符。
根据字符串的最后一个字符是奇数还是偶数来判断奇偶性。
实现代码如下:
#include <bits/stdc++.h>
using namespace std;
int N, a;
char ch[1010];
int main() {
cin >> N;
while (N --) {
cin >> ch;
a = ch[ strlen(ch) - 1 ] - '0';
puts(a % 2 ? "odd" : "even");
}
return 0;
}