标签:输入 内存 测试用例 输出 数组 ble 问题 顺序 can
给定区间[-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开始)。
4
1 2 3
2 3 4
2147483647 0 2147483646
0 -2147483648 -2147483647
Case #1: false31
Case #2: true
Case #3: true
Case #4: false
思路:
判断大小不难,只是本题一些细节需要注意:
1、给定区间[-2的31次方, 2的31次方]内的3个整数A、B和C
需要注意各种类型可以的取值范围。在不同编译器下int可能为2字节或4字节,若为4字节,取值范围是-2
~(231
-1)
2、溢出问题
若全部使用int类型,需要考虑到:若A、B同符号取两个此范围内绝对值大的数,C有可能出现溢出。
溢出解决方法:用double类型(或long long?)或判断同号情况下是否溢出
3、在讨论区看见有同学因为Case没大写首字母而不能AC的(⊙﹏⊙)b
1 #include<stdio.h> 2 int main(){ 3 int count,i; 4 double string[10][3]={{0}}; 5 6 scanf("%d",&count); 7 8 for(i=0;i<count;i++){ 9 scanf("%lf %lf %lf",&string[i][0],&string[i][1],&string[i][2]); 10 } 11 for(i=0;i<count;i++){ 12 if(string[i][0]+string[i][1]>string[i][2]) 13 printf("Case #%d: true\n",i+1); 14 else 15 printf("Case #%d: false\n",i+1); 16 } 17 return 0; 18 }
除了二维数组,还能用abc三个数组分别存,每次取对应位置比较即可。
标签:输入 内存 测试用例 输出 数组 ble 问题 顺序 can
原文地址:http://www.cnblogs.com/AndKuang17/p/6691187.html