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:用int型
#include "stdio.h"
int main(){
int n,d[1010]={0};
int a,b,c;
scanf("%d",&n);
for(int i=0;i<n;i++){
scanf("%d%d%d",&a,&b,&c);
a=a%1000007;
b=b%1000007;
c=c%1000007; //通过取余防止数的溢出
if(a+b>c){
d[i]=1; //通过判断d[i]的是否等于1来判断表达式是否成立
}
}
for(int i=0;i<n;i++){
if(d[i]==1)
printf("Case #%d: true",i+1);
else
printf("Case #%d: false",i+1);
if(i!=n-1)
printf("\n");
}
}
方法2 直接用long long 来定义
#include "stdio.h"
int main(){
int n,d[1010]={0};
long long a,b,c;
scanf("%lld",&n);
for(int i=0;i<n;i++){
scanf("%lld%lld%lld",&a,&b,&c);
if(a+b>c){
d[i]=1;
}
}
for(int i=0;i<n;i++){
if(d[i]==1)
printf("Case #%d: true",i+1);
else
printf("Case #%d: false",i+1);
if(i!=n-1)
printf("\n");
}
}