牛客网 PAT 乙级 1001 A+B和C (15)

题目链接:

https://www.nowcoder.com/pat/6/problem/4077


题目要点:

①   [-2的31次方, 2的31次方]

所以 a b c 都要用double类型的

我自己试着用 int a;int b;double c;  就会出现下面这样:

测试用例:
1
-2147483648 -2147483648 -2147483648

对应输出应该为:

Case #1: false

你的输出为:

Case #1: true

没搞懂,所以索性直接就都用了double型吧。

输入第1行给出正整数T(<=10),是测试用例的个数

遇到这样的,我一般就直接将最大值(10)设为数组的大小,a[10];

这样输入 n,就可以像下面这样来控制:

for (i = 0; i < n; i++) {
...
}

③ 观察输入例子,输出例子 

从输入例子中可以看到,a的值会达到 2147483647 -2147483648 所以这也建议我们直接用double类型。

在输出例子中, Case #1: ,是直接从 1 开始的,所以在写这个的时候

for (i = 0; i < n; i++) {
...
}

要改成

for (i = 1; i <= n; i++) {
...
}

最后,观察例子,在输入n后,连续输入几组 a b c ,进行程序处理后,在连续输出结果

我的办法是:在输入a b c 后,紧跟着用if语句进行判断,用数组a[i]储存比较的结果 (0=false,1=true)

然后再用for循环,同一输出结果

for (i = 1; i <= n; i++) {
if (p[i] == 1)
printf("Case #%d: true\n", i);
else
printf("Case #%d: false\n", i);
}


下面是完整程序:

#include
#include
#include
 
int main() {
     int n;
     scanf( "%d" , &n);
     double a, b;
     double c;
 
     int p[ 10 ];
     int i;
     for (i =  1 ; i <= n; i++) {
         scanf( "%lf %lf %lf" , &a, &b, &c);
         if (a + b > c)
             p[i] =  1 ;
         else p[i] =  0 ;
     }
 
     for (i =  1 ; i <= n; i++) {
         if (p[i] ==  1 )
             printf( "Case #%d: true\n" , i);
         else
             printf( "Case #%d: false\n" , i);
     }
     
 
 
     return 0 ;
 
}



(~ ̄▽ ̄)~

测试点

测试点 结果 用时(ms) 内存(KB)
1 答案正确 3 244
2 答案正确 3 384
3 答案正确 2 256
4 答案正确 3 380
5 答案正确 3 384
6 答案正确 3 384
7 答案正确 3 384
恭喜你做对本题!你的代码排在 第4578位, 快去把思路  分享给大家 吧!




你可能感兴趣的:(牛客网 PAT 乙级 1001 A+B和C (15))