1. 程式人生 > >PAT (Basic Level) Practice (中文)1011 A+B 和 C (15 分) (C++)(兩種方案)

PAT (Basic Level) Practice (中文)1011 A+B 和 C (15 分) (C++)(兩種方案)

1011 A+B 和 C (15 分)

給定區間 [−2
​31
​​ ,2
​31
​​ ] 內的 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


//方案1 用long long int型別進行儲存,無需判斷是否發生了越界
#include <cstdio>
#include <cstring>

int main()
{
	int T = 0;
	scanf("%d", &T);
	for (int i = 1; i <= T; i++)
	{
	  long long int A, B, C;//定義為long long int型別
		scanf("%lld %lld %lld"
, &A, &B, &C);//注意long long int型別的輸入格式 if (A - C + B > 0) printf("Case #%d: true\n", i);//輸出時需加\n換行 else printf("Case #%d: false\n", i); } return 0; }
//方案2 用int型別進行儲存,判斷是否發生了越界再做比較
#include <cstdio>
#include <cstring>


int main()
{
	int T = 0;
	int A, B, C;
	scanf("%d", &
T); for (int i = 1; i <= T; i++) { scanf("%d %d %d", &A, &B, &C); int D = A + B; if (D<0 && A>0 && B>0) printf("Case #%d: true\n", i);//判斷越界時的狀態 else if(D > 0 && A<0 && B < 0) printf("Case #%d: false\n", i); else if(D>C) printf("Case #%d: true\n", i);//否則正常比較輸出即可 else printf("Case #%d: false\n", i); } return 0; }