【ACM之路】1.什么时候用long long 型

  • 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给予了更详细的介绍,在此表示感谢!

 

 

  • 13
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值