题目描述
给定区间 [−231 ,231 ] 内的 3 个整数 A、B 和 C,请判断 A+B 是否大于 C。
输入格式
输入第 1 行给出正整数 T (≤10),是测试用例的个数。随后给出 T 组测试用例,每组占一行,顺序给出 A、B 和 C。整数间以空格分隔。
输出格式
对每组测试用例,在一行中输出 Case #X: true 如果 A+B>C,否则输出 Case #X: false,其中 X 是测试用例的编号(从 1 开始)。
输入样例
4
1 2 3
2 3 4
2147483647 0 2147483646
0 -2147483648 -2147483647
输出样例
Case #1: false
Case #2: true
Case #3: true
Case #4: false
思路
输入 T,用以表示下面输入的数据组数,同时令 tcase 表示当前是第几组数据,初值为 1 。
对魅族数据,判断 A+B 是否大于 C :
① 若 A+B>C,则输出 Case #%d: true,其中%d 为当前的 tcase 值。
② 否则,输出 Case #%d: false,其中 %d 为当前的 tcase 值。
注意点
题目给出的范围是 [ -2131,231],首先需要知道 int 型的数据范围是 [ -2131,231-1],在最大值这里就会超过 int 型的范围。另外,两个 int 型变量相加,最后是可能超过 int 型的,因此在本题中,必须使用 long long 作为 ABC 的变量类型,输入、输出格式必须是 %lld,否则就会返回 “答案错误” 。
代码:
#include <stdio.h>
int main() {
int T;
scanf("%d", &T);
long long A[T], B[T], C[T];
for(int i=0; i<T; i++) {
scanf("%lld %lld %lld", &A[i], &B[i], &C[i]);
}
for(int i=0; i<T; i++) {
if((A[i] + B[i]) > C[i]) {
printf("Case #%d: true\n", i+1);
} else {
printf("Case #%d: false\n", i+1);
}
}
return 0;
}
结果: