A+B和C (15)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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: 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三个数组分别存,每次取对应位置比较即可。
以上是关于A+B和C (15)的主要内容,如果未能解决你的问题,请参考以下文章