題目描述
劃拳是古老中國酒文化的一個有趣的組成部分。酒桌上兩人劃拳的方法為:每人口中喊出一個數字,同時用手比劃出一個數字。如果誰比劃出的數字正好等于兩人喊出的數字之和,誰就輸了,輸家罰一杯酒。兩人同贏或兩人同輸則繼續下一輪,直到唯一的贏家出現。
下面給出甲、乙兩人的酒量(最多能喝多少杯不倒)和劃拳記錄,請你判斷兩個人誰先倒。
輸入格式:
輸入第一行先后給出甲、乙兩人的酒量(不超過100的非負整數),以空格分隔。下一行給出一個正整數
N
(≤100),隨后N
行,每行給出一輪劃拳的記錄,格式為:甲喊 甲劃 乙喊 乙劃
其中
喊
是喊出的數字,劃
是劃出的數字,均為不超過100的正整數(兩只手一起劃)。
輸出格式:
在第一行中輸出先倒下的那個人:
A
代表甲,B
代表乙。第二行中輸出沒倒的那個人喝了多少杯。題目保證有一個人倒下。注意程序處理到有人倒下就終止,后面的數據不必處理。
輸入樣例:
1 1 6 8 10 9 12 5 10 5 10 3 8 5 12 12 18 1 13 4 16 12 15 15 1 1 16
輸出樣例:
A 1
?程序代碼
#include<stdio.h>
int main(){int a,b;scanf("%d %d",&a,&b);//輸入甲和乙的酒量int N;int count=0,num=0;//用來統計甲和乙罰酒的數量scanf("%d",&N);//輸入測試的案例數int x,y,z,q;for(int i=0;i<N;i++){scanf("%d %d %d %d",&x,&y,&z,&q);//輸入甲喊,甲劃,乙喊,乙劃的數值if(y==x+z&&q!=y){//當滿足甲罰酒時,count加1count++;}if(q==x+z&&y!=q){//當滿足乙罰酒時,num加1num++;}if(count>a){//當甲罰酒的量大于甲的酒量時printf("A\n");printf("%d",num);break;}if(num>b){//當乙罰酒的量大于乙的酒量時printf("B\n");printf("%d",count);break;}}return 0;
}