A+B和C (15)
时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB
题目描述
给定区间[-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: false Case #2: true Case #3: true Case #4: false 思路:判断大小不难,只是本题一些细节需要注意: 1、给定区间[-2的31次方, 2的31次方]内的3个整数A、B和C 需要注意各种类型可以的取值范围。在不同编译器下int可能为2字节或4字节,若为4字节,取值范围是-2
31
~(2
31
-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三个数组分别存,每次取对应位置比较即可。
时间: 2024-10-25 10:56:34