L1-019. 谁先倒-阿里云开发者社区

开发者社区> 云计算> 正文

L1-019. 谁先倒

简介: L1-019. 谁先倒 划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。

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>
using namespace std;
int main() 
{
    int a, b;
    int flag = 0; 
    int count;  //没倒的人的杯数 
    cin >> a >> b;
    int n;
    cin >> n;
    int aa = 0, bb = 0;
    for(int i = 0; i < n; i++) {
        int j, jj, y, yy;
        cin >> j >> jj >> y >> yy;  //甲喊 甲划 乙喊 乙划
        if(jj == j + y && yy != j + y) {    //甲输 
            aa++; 
        } else if(yy == j + y && jj != j + y) {
            bb++;
        } 
        if(aa > a) {        
                flag = 1;
                count = bb;
                break;

        }
        if(bb > b) {
                 flag = 2;
                 count = aa;
                 break;
        } 
    } 
    if(flag == 1) {
        cout << "A" <<endl;
        cout <<count; 
    } else {
        cout << "B" <<endl;
        cout <<count; 
    }
    return 0; 
} 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
云计算
使用钉钉扫一扫加入圈子
+ 订阅

时时分享云计算技术内容,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。

其他文章