1011 A+B 和 C
题目:
给定区间 [−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
代码:
#include<iostream>
using namespace std;
int main() {
//注意本题用数据类型long就可以解决,不需要在使用字符串数组来解决
long A, B, C;
int T;
int i;
cin >> T;
for (i = 0; i < T; i++) {
cin >> A >> B >> C;
if (A + B > C) {
cout << "Case #" << i + 1 << ": true"<<"\n";
}
else {
cout << "Case #" << i + 1 << ": false" << "\n";
}
}
}
//Long的最小值 = -2 ^ 31
//Long的最大值 = 2 ^ 31 - 1
注意:
对于本题来讲范围为 [−2^31 ,2 ^31] ,用long正好是可以的。不需要在使用字符数组来实现。
补充:
①long long是C++整型类型之一,占8字节64位,表示范围为
-2^63 ~ 2^63-1
②long 的最小值 = -2 ^ 31 long 的最大值 = 2 ^ 31 - 1
unsigned int 0~4294967295
int -2147483648~2147483647
unsigned long 0~4294967295
long -2147483648~2147483647
long long的最大值:9223372036854775807
long long的最小值:-9223372036854775808
unsigned long long的最大值:1844674407370955161
__int64的最大值:9223372036854775807
__int64的最小值:-9223372036854775808
unsigned __int64的最大值:18446744073709551615