首页 > 代码库 > A+B和C (15)

A+B和C (15)

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三个数组分别存,每次取对应位置比较即可。



A+B和C (15)