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<iostream>
#include<cstdlib>
using namespace std;
struct Caiquan{
int Acai,Achu;
int Bcai,Bchu;
};
int main()
{
int JLA,JLB;
int N,i,cntA,cntB;
cntA=0;
cntB=0;
cin>>JLA>>JLB;
cin>>N;
Caiquan *Q;
char A[100];
//0 A,1 B,2 ping
Q=(Caiquan *)calloc(100,sizeof(Caiquan));
for(i=0;i<N;i++)
{
cin>>Q[i].Acai>>Q[i].Achu>>Q[i].Bcai>>Q[i].Bchu;
if(Q[i].Achu!=Q[i].Bchu&&(Q[i].Achu==(Q[i].Acai+Q[i].Bcai)))
A[i]='0';
else if(Q[i].Achu!=Q[i].Bchu&&(Q[i].Bchu==(Q[i].Acai+Q[i].Bcai)))
A[i]='1';
else
A[i]='2';
}//这部分代码可以优化,结构体完全没有体现它的用处
for(i=0;i<N;i++)
{
if(A[i]=='0')
cntA++;
if(A[i]=='1')
cntB++;
if(cntA>JLA){
cout<<"A"<<endl;
cout<<cntB<<endl;
break;
}
if(cntB>JLB){
cout<<"B"<<endl;
cout<<cntA<<endl;
break;
}
}
//所有的信息已经成功录入
return 0;
}