(pat乙級1011)
給定區間 [−231,231] 內的 3 個整數 A、B 和 C,請判斷 A+B 是否大於 C。
輸入格式:
輸入第 1 行給出正整數 T (≤10),是測試用例的個數。隨後給出 T 組測試用例,每組佔一行,順序給出 A、B 和 C。整數間以空格分隔。
輸出格式:
對每組測試用例,在一行中輸出 Case #X: true 如果 A+B>C,否則輸出 Case #X: false,其中 X 是測試用例的編號(從 1 開始)。
輸入樣例:
4
1 2 3
2 3 4
2147483647 0 2147483646
0 -2147483648 -2147483647
輸出樣例:
Case #1: false
Case #2: true
Case #3: true
Case #4: false
c++代碼:
#include<iostream>
#define max 100000
using namespace std;
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++){
long long a,b,c; //聲明爲long long防止運算越界
cin>>a>>b>>c;
cout<<"Case #"<<i+1<<":";
if(a+b>c)cout<<" true"<<endl;
else cout<<" false"<<endl;
}
return 0;
}
注意:
不需要用到大整數加減法運算,a,b,c聲明爲long long型即可防止運算越界(int型max a+int型max b越界)。
(a,b,c聲明爲int不能AC。
也可只聲明a,b,c其中一個爲long long,因爲多個不同類型變量參與運算,其他變量都會自動被轉化爲“最長"的類型:如int—>double int -->long long short–>int …)