![【PAT(甲级)】1065 A+B and C (64bit)[相加时关于编译器的错误],第1张 【PAT(甲级)】1065 A+B and C (64bit)[相加时关于编译器的错误],第1张](/aiimages/%E3%80%90PAT%EF%BC%88%E7%94%B2%E7%BA%A7%EF%BC%89%E3%80%911065+A%2BB+and+C+%2864bit%29%5B%E7%9B%B8%E5%8A%A0%E6%97%B6%E5%85%B3%E4%BA%8E%E7%BC%96%E8%AF%91%E5%99%A8%E7%9A%84%E9%94%99%E8%AF%AF%5D.png)
Given three integers A, B and C in (−,), you are supposed to tell whether A+B>C.
Input Specification:The first line of the input gives the positive number of test cases, T (≤10). Then T test cases follow, each consists of a single line containing three integers A, B and C, separated by single spaces.
Output Specification:For each test case, output in one line Case #X: true if A+B>C, or Case #X: false otherwise, where X is the case number (starting from 1). Each line should ends with '\n'.
Sample Output:3
1 2 3
2 3 4
9223372036854775807 -9223372036854775808 0
解题思路:Case #1: false
Case #2: true
Case #3: false
给出的数字在 (−,)的范围内,也就是long long int 的范围内,那么两个long long int 相加如果正数变成负数,说明溢出,也就是肯定大于第三个数;如果两个负数相加,变成正数,那么就是负溢出,肯定小于第三个数。
易错点:代码大家应该都能按照这个思路敲出来,但是有个小bug,例如你用pat上的C++(g++)的编译器时:
如果你不把注释掉的代码加上,那运行结果就会出错;
但如果你用的时C++(clang++)的编译器时,你就可以不用加上注释掉的那行代码。
本质原因应该是因为如果你不定义和的类型的话,有些编译器会把long long int类型数字相加默认变成long int 类型的相加,就会导致结果出错。
同一段代码:
这是C++(g++)编译器的运行结果:
这是C++(clang++)的运行结果:
代码:#include
using namespace std;
int main(){
int T;
scanf("%d",&T);
long long int A,B,C;
for(int i=0;i0&&B>0&&A+B<=0){
printf("Case #%lld: true\n",i+1);
}else if(A<0&&B<0&&A+B>=0){
printf("Case #%lld: false\n",i+1);
}else{
if(A+B>C){
printf("Case #%lld: true\n",i+1);
}else{
printf("Case #%lld: false\n",i+1);
}
}
}
return 0;
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)