C++入门 PAT乙级B1046 猜拳

C++入门 PAT乙级B1046 猜拳

一次调成功!爽歪歪
题目描述

划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。

下面给出甲、乙两人的划拳记录,请你统计他们最后分别喝了多少杯酒。

输入格式

输入第一行先给出一个正整数 N(≤100),随后 N 行,每行给出一轮划拳的记录,格式为:

甲喊 甲划 乙喊 乙划

其中喊是喊出的数字,划是划出的数字,均为不超过 100 的正整数(两只手一起划)。

输出格式

在一行中先后输出甲、乙两人喝酒的杯数,其间以一个空格分隔。

输入样例

5
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15

输出样例

1 2

思路分析

(1)仍然是N单独输入存储到一个整型变量中。其余的输入内容通过合法判断后,存储到数组中。

(2)这道题目其实很好理解意思。
比如一次划拳的记录为 a b c d。其中若是 a+c等于b且不等于d,则甲获胜、乙输掉喝酒一杯。若是 a+c等于d且不等于b,则乙获胜、甲输掉喝酒一杯。若是 a+c等于b且等于d,则甲、乙都获胜、都不喝酒。若是 a+c不等于b且不等于d,则甲、乙都输、都不喝酒。
转换到代码层面也只是简单的加和后比较是否相等。要注意使用数组的话,需要注意下标对应的是什么。

(3)仍然要注意输入数据的合法性与错误处理。在此不再赘述。

代码

#include<iostream>
#include <stdio.h>

using namespace std;
int main()
{
    int num_in[400];   //甲、乙两人数据存储
    int i=0;
    char c;
    int N;             //总划拳次数
    int A=0,B=0;       //记录甲、乙的喝酒次数
    bool flag1=false; //判断甲是否胜利
    bool flag2=false; //判断乙是否胜利
    cin>>N;   //输入划拳次数
    c=getchar();  //获取输入字符
    if(N>100||c!='\n'||N<0)
    {
        return 0;
    }
    while(i<N*4)  //终止条件为数组中的数达到应有的存储数目
    {
        c=getchar();  //获取输入字符
        if((c>='0'&&c<='9'))  //输入正整数
		{
			ungetc(c,stdin);
			cin>> num_in[i];
			if(num_in[i]<0||num_in[i]>100)   //错误处理
            {
                return 0;
            }
            else {i++;}
		}

    }

        for(int j=0;j<i;j=j+4)
    {
        if(num_in[j]+num_in[j+2]==num_in[j+1])  //甲猜对了
        {
            flag1=true;
        }
         if(num_in[j]+num_in[j+2]==num_in[j+3])  //乙猜对了
        {
            flag2=true;
        }
        if(flag1!=flag2)   //只有一个人获胜、另外一个输,才会喝酒
        {
            if(flag1==true) B++;  //甲赢,乙喝酒
            if(flag2==true) A++;  //乙赢,甲喝酒
        }
        flag1=flag2=false;
    }
    cout<<A<<' '<<B;
    return 0;
}

参考注释看代码。若仍然有疑问,请看思路分析或者留言、私信版主

结果截图

在这里插入图片描述
在这里插入图片描述如需转载,请联系版主!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值