1065. A+B and C (64bit)

检测int加法溢出用(a>0&&b>0&&b>INT_MAX-a) ||(a<0&&b<0&&b<INT_MIN-a) 

long long范围是[-2^63, 2^63),但这里的范围是[-2^63, 2^63],如果对于a,b,c分别为2^63 ,0,2^63的情况,long long 根本就不能存这种数,所以用long long 来做这个题是不对的,必须自己做一个大整数的加减法或用java等的大整数功能,所以,我使用long double存的。。。

#include<iostream>
using namespace std;
char T[]="Case #%d: true\n";
char F[]="Case #%d: false\n";
int main(){
  int n;cin>>n;
  for(int i=1;i<=n;++i){
    long double a,b,c;
    cin>>a>>b>>c;
    printf(a+b>c?T:F,i);
  }
}


你可能感兴趣的:(1065. A+B and C (64bit))