题目链接:
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<stdio.h>
#include<math.h>
#include<string.h>
int