题目描述:
给定区间 [−2^31,2^31] 内的 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
作者 HOU, Qiming
单位 浙江大学
代码长度限制 16 KB
时间限制 400 ms
内存限制 64 MB
题解:
分析一下题目:A和B都在 [−2^31,2^31] 内,这刚好是int型数字的范围,但两个数加起来可能会溢出,所以我们longlong型。
代码如下:
#include<stdio.h>
int main()
{
int T, i;
long long A[10], B[10], C[10], S[10];
scanf("%d", &T);
for(i = 0; i < T; i++)
{
scanf("%lld%lld%lld", &A[i], &B[i], &C[i]);
S[i] = A[i] + B[i];
}
for(i = 0; i < T; i++)
{
if(S[i] > C[i])
printf("Case #%d: true", i+1);
else
printf("Case #%d: false", i+1);
if(i != T-1)
printf("\n");
}
return 0;
}