-
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.csdn.net/junecau/article/details/6766033给予了更详细的介绍,在此表示感谢!