题目描述
给定区间[-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开始)。
输入例子:
41 2 32 3 42147483647 0 21474836460 -2147483648 -2147483647
输出例子:
Case #1: falseCase #2: trueCase #3: trueCase #4: false
这题的坑就是a,b的范围是int型,但a+b的范围有可能超过int型,所以得设成long型。
代码:
#include<iostream>
using namespace std;
int main()
{int t;cin>>t;for(int i=1;i<=t;i++){long a,b,c;cin>>a>>b>>c;if(a+b>c)cout<<"Case #"<<i<<": true"<<endl;elsecout<<"Case #"<<i<<": false"<<endl;}return 0;
}