PAT A1065 A+B and C (64bit)

题目描述


分析:

由于 long long 的范围是 [ − 2 63 [-2^{63} [263, 2 63 ) 2^{63}) 263),因此题目中给出的两个整数相加有可能会溢出(正溢出或负溢出),直接进行大小判断会造成错误。对于溢出后的具体范围,可以进行如下分析:

① 当 A + B ≥ 2 63 A + B ≥ 2^{63} A+B263时,显然有 A + B > C A + B > C A+B>C 成立,但 A + B A + B A+B 会因超过 long long 的正向最大值而发生正溢出。由于题目给定的 A A A B B B 最大均为 2 63 − 1 2^{63} - 1 2631,故 A + B A + B A+B 最大为 2 64 − 2 2^{64} - 2 2642,因此使用 long long 存储正溢出后的值的区间为 [ − 2 63 [-2^{63} [263, 2 ] 2] 2]。所以当 A > 0 , B > 0 , A + B < 0 A > 0,B > 0,A + B < 0 A0B0A+B0 时为正溢出,输出 true。

② 当 A + B < − 2 63 A + B < -2^{63} A+B263时,显然有 A + B < C A + B < C A+B<C 成立,但 A + B A + B A+B 会因超过 long long 的负向最小值而发生负溢出。由于题目给定的 A A A B B B 最小均为 − 2 63 -2^{63} 263,故 A + B A + B A+B 最小为 − 2 64 -2^{64} 264,因此使用 long long 存储正溢出后的值的区间为 [ 0 [0 [0, 2 63 ) 2^{63}) 263)。所以当 A < 0 , B < 0 , A + B ≥ 0 A < 0,B < 0,A + B ≥ 0 A<0B<0A+B0 时为负溢出,输出 false。

③ 在没有溢出的情况下,当 A + B > C A + B > C A+B>C 时,输出 true;当 A + B ≤ C A + B ≤ C A+BC 时,输出false。


代码(C++)

#include <iostream>

using namespace std;

int main()
{
    int T;
    cin >> T;
    bool flag;
    int i = 1;
    while (T --)
    {

        long long a, b, c;
        scanf("%lld%lld%lld", &a, &b, &c);
//         cin >> a >> b >> c;  这里不要用 cin 输入,有一组数据会过不去
        long long sum = a + b;  

        if (a > 0 && b > 0 && sum < 0) flag = true; // 正溢出为 true
        else if (a < 0 && b < 0 && sum >= 0) flag = false; // 负溢出为 false
        else if (sum > c) flag = true; // 无溢出 判断 A + B
        else if (sum <= c) flag = false;
        
        if (flag == true) cout << "Case #" << i ++ << ": true" << endl;
        else cout << "Case #" << i ++ << ": false" << endl;
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值