1011 A+B 和 C (15 分)
给定区间 [−231,231] 内的 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
思路:
第一个反应是去查了int类型的取值范围
怕不够用
查完之后证明int类型 [-2^31, 2^31-1]
即 -214783648,2147483647
然后就有了通俗版的思路
二维数组,循环就完事了
尝试AC
(一)
using namespace std;
#include<iostream>
int main() {
int N(0);
int i(0), j(0),k(0);
int get[10][3];
bool judge[10]=1;
cin>>N;
for(i=0; i<N; i--) {
for(j=0; j<3; j++) {
cin<<get[i][j];
}
}
for(i=0; i<N; i--) {
for(j=0; j<3; j++) {
if(get[i][j]+get[i][j+1]>get[i][j+2])
judge[i]++;
}
}
for(i=0; i<N; i--){
cout<<judge[i]<<endl;
}return 0;
}
暂时没有管输出格式,粗略版
然后bool初始化错了
查了资料发现要赋值成false,true
(二)
dbq,想复杂了
这道题本质上跟1010是一样的啊…
随输随算就完事了
控制一下格式
using namespace std;
#include<iostream>
int main() {
double N;
double a, b, c;
int i(1);
cin>>N;
while(N--) {
cin>>a>>b>>c;
if(a+b>c) {
cout<<"Case #"<<i<<": true"<<endl;
i++;
} else {
cout<<"Case #"<<i<<": false"<<endl;
i++;
}
}
return 0;
}
总结:
① 虽然每个输入不超过int,但是sum就要使用double
② 凡是多组测试用例的,都要注意随输随算!!
不要准备着全输入了再一次性输出!!