给定区间[-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
分析:PAT上边输入边输出和输入结束后再输出的结果是一样的。因此,可先读入次数,然后循环,在读入后,直接判断输出。区间[-231, 231]是相当于四个字节所表示的范围。为了避免溢出,应该使用八个字节的整型变量。不同环境下long所占字节数不同。
下列代码运行于VS2015,修改scanf_s即可在PAT上运行。
#include<stdio.h>
int main(void) {
int n = 0;
int temp;
long long v1 = 0, v2=0, v3 = 0;
scanf_s("%d", &n);
for (temp = 0; temp < n; temp++) {
scanf_s("%lld %lld %lld", &v1, &v2, &v3);
printf("Case #%d: %s\n", temp + 1, v1 + v2>v3 ? "true" : "false");
}
return 0;
}