PTA 团体设计天梯赛 L1- 019 谁先倒
题目内容
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。
输入格式:
输入第一行先后给出甲、乙两人的酒量(不超过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, N, A3 = 0, B3 = 0; //A B 分别代表甲 乙的酒量, N 代表划拳次数, A3 B3 分别代表甲乙输得次数
scanf("%d %d", &A, &B);
scanf("%d", &N);
int A1[N], A2[N], B1[N], B2[N]; //A1 甲喊,A2 甲划,同理B1,B2
for(int i = 0; i < N; i++) {
scanf("%d %d %d %d", &A1[i], &A2[i], &B1[i], &B2[i]);
//分别输入 甲喊,甲划,乙喊,乙划
// printf("%d %d %d %d\n", A1[i], A2[i], B1[i], B2[i]); //测试
}
for(int i = 0; i < N; i++) {
if(A2[i] == B2[i]) { //甲乙划拳一样,意味着同输或者同赢
continue; A3++; B3++;
}
if(A2[i] == A1[i]+B1[i]) //甲划 == 甲乙喊得数之和
A3++;
if(B2[i] == A1[i]+B1[i]) //乙划 == 甲乙喊得数之和
B3++;
// printf("%d %d\n", A3, B3); //测试
if(A3 == A+1) { //甲先醉倒
printf("A\n");
printf("%d", B3);
break;
}
if(B3 == B+1) { //乙先醉倒
printf("B\n");
printf("%d", A3);
break;
}
}
}
一开始WA了,没有注意到以下几个点
1.划出的数字正好等于两人喊出的数字之和,谁就输了(我弄反了)
2.喝酒次数等于酒量得时候还没有醉倒,还得再喝一杯才算醉倒
3.两人同输得时候也得喝酒