PAT 1065 A+B and C (64bit)

这一题很浅显,就是让求A+B>C,如果符合条件则输出true,反之输出false

按道理说直接模拟即可,但是因为C的范围很大,在-2^63, 到 2^36之间,A和B同样会很大,那么就可能出现A+B溢出,即超出数据类型的范围。

因此我们要考虑溢出的情况:

cpp 复制代码
        else if(A>0&&B>0&&A+B<=0)
		{
		    cout<<"Case #"<<i+1<<": ";
    		cout<<"true"<<endl;
		}
		else if(A<0&&B<0&&A+B>=0) 
		{
			cout<<"Case #"<<i+1<<": ";
    		cout<<"false"<<endl;
		}

存在这两种溢出的情况。

那么就可以得出完整代码:

cpp 复制代码
#include <iostream>
#include <limits.h>
#include <cstring>
#include <queue>
#include <unordered_map>
#include <algorithm>
#include <cmath>
#include <vector>
#include <map>
#include <set>
using namespace std;
 long long A;
  long long B;
  long long C; 
int main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    int T;
    cin>>T;
    for(int i=0;i<T;i++)
    {
    	cin>>A>>B>>C;
    	
        long long sum=A+B;
		 if(A>0&&B>0&&sum<0)
		{
		    cout<<"Case #"<<i+1<<": ";
    		cout<<"true"<<endl;
		}
		else if(A<0&&B<0&&sum>=0) 
		{
			cout<<"Case #"<<i+1<<": ";
    		cout<<"false"<<endl;
		}
        else if(sum>C)
        {
             cout<<"Case #"<<i+1<<": ";
    		cout<<"true"<<endl;
        }
		else
		{
				cout<<"Case #"<<i+1<<": ";
    		    cout<<"false"<<endl;
		}
	}
	return 0;
 } 

这里需要注意一定要先判断溢出,在比较的时候应该先让A+B的值放到一个变量里面,而不是直接:

cpp 复制代码
A+B<=0
A+B>=0

因为在cpp中会先把B移到右边,再比较,而不是先加减再比较。

因此我们应该用sum=A+B。

相关推荐
I_LPL1 天前
hot100贪心专题
数据结构·算法·leetcode·贪心
颜酱1 天前
DFS 岛屿系列题全解析
javascript·后端·算法
WolfGang0073211 天前
代码随想录算法训练营 Day16 | 二叉树 part06
算法
2401_831824961 天前
代码性能剖析工具
开发语言·c++·算法
Sunshine for you1 天前
C++中的职责链模式实战
开发语言·c++·算法
qq_416018721 天前
C++中的状态模式
开发语言·c++·算法
2401_884563241 天前
模板代码生成工具
开发语言·c++·算法
2401_831920741 天前
C++代码国际化支持
开发语言·c++·算法
m0_672703311 天前
上机练习第51天
数据结构·c++·算法
ArturiaZ1 天前
【day60】
算法·深度优先·图论