L1-019 谁先倒 (15 分)

谁先倒 (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

**总结:**这道题目是比较简单的,但是这里面有我们需要注意的地方,在我们统计A或B喝酒的数量的时候的条件是符合甲而不符合乙,或符合乙不符合甲。我们在判断谁倒时是谁最多喝的杯数+1。

代码实现:

复制代码
#include<stdio.h>
int main()
{
	int Amax = 0, Bmax = 0;
	scanf("%d %d", &Amax, &Bmax);
	int n = 0;
	scanf("%d", &n);
	int i = 0,jhua=0,jhan=0,yhua=0,yhan=0,jh=0,yh=0;
	for (i = 0;i < n;i++)
	{
		scanf("%d %d %d %d", &jhan, &jhua, &yhan, &yhua);
		if (jhua == jhan + yhan&&yhua!=jhan+yhan)
		{
			jh++;
		}
		else if (yhua == jhan + yhan&&jhua!=jhan+yhan)
		{
			yh++;
		}
		if (jh == Amax+1 || yh == Bmax+1)
			break;
	}
	if (jh == Amax + 1)
	{
		printf("A\n");
		printf("%d", yh);
	}
	else if (yh == Bmax + 1)
	{
		printf("B\n");
		printf("%d", jh);
	}
	return 0;
}
相关推荐
吃好睡好便好8 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅9 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
x_yeyue11 小时前
三角形数
笔记·算法·数论·组合数学
Mr. zhihao12 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
念何架构之路12 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星12 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑12 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光13 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩13 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947313 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表