7-114 谁先倒 (15分) 划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了

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

下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。

输入格式:

输入第一行先后给出甲、乙两人的酒量(不超过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

扫描二维码关注公众号,回复: 13267144 查看本文章
#include <stdio.h>
int main()
{
    
    
	int J,i=0,Y,m=0,N,z=0;    // 定义甲和乙的初始杯数并初始化为0。 
	int jhan,jhua,yhan,yhua;
	scanf("%d %d %d",&J,&Y,&N);            // 根据题意,现将不用放入数组的数据读入。 
	int sz[400];                           // 因为要读入几组数据,所以先定义一个数组,记得开大些,不然可能越界。 
	for(z=0;z<N*4;z+=4)                    // 既然给了有几组数据( N ),就要好好利用下,设定为读入的边界。 
	{
    
                                          // *4 和 +4 是因为每次读入 4 个数据。 ( 当然,一个一个的读入也可以 ) 
		scanf("%d %d %d %d",&sz[z],&sz[z+1],&sz[z+2],&sz[z+3]);
	}
	z=0;                                   // 读入完数据后,自然是根据数据进行相关计算。 
	while (1)
	{
    
    
		if(sz[z+1]==sz[z]+sz[z+2]&&sz[z+3]!=sz[z]+sz[z+2])   // 这是甲输的情况,记得排除此时乙也输的情况。 
		{
    
    
			i++;             // i++ ,用来记录甲喝酒的情况。 
			if(i>J)          // 当 i > J ,自然是甲喝醉了 。 
			{
    
    
				printf("A\n");         // 接下来自然是依照题意输出了。 
				printf("%d",m);
				break;
			}
		}
		if(sz[z+3]==sz[z]+sz[z+2]&&sz[z+1]!=sz[z]+sz[z+2])   // 这自然是乙输的情况,同样记得排除甲也输的情况。 
		{
    
    
			m++;             // m++ ,用来记录乙喝酒的情况。 
			if(m>Y)          // 当 m > Y ,自然是乙喝醉了。 
			{
    
    
				printf("B\n");
				printf("%d",i);        // 依照题意输出。 
				break;
			}
		}
		z+=4;           //因为每四个为一组数据,所以自然是 z += 4  
	}
}

博主是刚学习的小白,所以大佬们轻点喷,写下自己的代码是因为网上似乎没有更适合初学者的答案,所以才为此下笔。

如果大佬们有更简明的代码,欢迎指教。

最后,各位看官,如果觉得写得不错,能不能给个赞啊。。

猜你喜欢

转载自blog.csdn.net/weixin_51304266/article/details/109677109