-
1.前景介绍
在做PAT(A+B and C)时,A+B和C,给定区间[-2^31, 2^31]内的3个整数A、B和C,请判断A+B是否大于C。
我首先用了int,发现溢出错误,查阅发现,int占4个字节,32位(数值范围即 -2147483648 ~ 2147483647,正负20亿内用int比较安全)
如果两个负数相加(如-2147483648和-2147483648就会发生数据溢出,二进制即32个1和二进制32个1相加,数据溢出,如果不懂可以查看唐朔飞老师《计算机组成原理》第六章补数相关知识),两个正数相加也可能(如2147483647,2147483647)。但是一正一负是不会溢出的,一定在合理范围内。
-
2.如何使用
所以这个时候可以用long long型(该数据类型在32位机中表示8个字节,即64位,符号位占一位,-9223372036854775808 ~ 9223372036854775807, 19位长,这是很大的数了),
所以要解决上边a+b>c的问题,即
long long a,b,c; //定义long long 型a,b,c
scanf("%lld%lld%lld",&a,&b,&c); //输入a,b,c
if(a+b>c)
printf("true\n"); //如果a+b>c,输出true
else
printf("false\n"); //否则输出false
-
3.感谢与引用
感谢无私分享的朋友们,我引用了 junecau的相关内容,他的博客https://blog.youkuaiyun.com/junecau/article/details/6766033给予了更详细的介绍,在此表示感谢!
本文探讨了在PAT竞赛中如何正确判断A+B是否大于C的问题。鉴于int型变量容易出现溢出的情况,文章详细解释了为何使用long long型变量能有效避免这一问题,并提供了具体的代码实现。
1718

被折叠的 条评论
为什么被折叠?



