Lipsky

PAT 1011 A+B 和 C

字数统计: 324阅读时长: 1 min
2019/03/18 Share

PAT 1011#

1011 A+B 和 C (15 分)#

给定区间 [−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 开始)。

输入样例:#

1
2
3
4
5
4
1 2 3
2 3 4
2147483647 0 2147483646
0 -2147483648 -2147483647

输出样例:#

1
2
3
4
Case #1: false
Case #2: true
Case #3: true
Case #4: false

分析:#

使用循环输入,然后每次判断输出。重要点在于:判断输入的数字的取值范围,int(-(2^15 -1)~(2^15-1) long(-(2^31 -1)) ~ (2^31 -1) long long( -(2^63 -1) ~ (2^63 -1) )

C++ 解法:#

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
using namespace std;

int main(){
long long int a, b, c;
int n;
cin >> n;
for(int i = 0; i < n; i++){
cin >> a >> b >> c;
if(a + b > c)
cout << "Case #" << i+1 << ": true"<<endl;
else
cout << "Case #" << i+1 << ": false"<<endl;
}

return 0;
}
CATALOG
  1. 1. PAT 1011#
    1. 1.1. 1011 A+B 和 C (15 分)#
    2. 1.2. 输入样例:#
    3. 1.3. 输出样例:#
    4. 1.4. 分析:#
    5. 1.5. C++ 解法:#