石头剪刀布

题目:
石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。

一天,小 A 和小 B 正好在玩石头剪刀布。已知他们的出拳都是有周期性规律的,比如:“石头-布-石头-剪刀-石头-布-石头-剪刀……”,就是以“石头-布-石头-剪刀”为周期不断循环的。请问,小 A 和小 B 比了 N 轮之后,谁赢的轮数多?

输入格式:
输入包含三行。

第一行包含三个整数:N,NA,NB,分别表示比了 N 轮,小 A 出拳的周期长度,小 B 出拳的周期长度。0 < N,NA,NB < 100;

第二行包含 NA 个整数,表示小 A 出拳的规律。

第三行包含 NB 个整数,表示小 B 出拳的规律。

其中,0 表示“石头”,2 表示“剪刀”,5 表示“布”。相邻两个整数之间用单个空格隔开。

输出格式:
输出一行,如果小 A 赢的轮数多,输出"A";如果小 B 赢的轮数多,输出"B";如果两人打平,输出 “draw”。

提示:
对于测试数据,猜拳过程为:
A:{0 2 5 0 2 5 0 2 5 0}
B:{0 5 0 2 0 5 0 2 0 5}

A 赢了 4 轮,B 赢了 2 轮,双方打平 4 轮,所以 A 赢的轮数多。

样例输入:
10 3 4
0 2 5
0 5 0 2

样例输出:
A

坑点:
数组不能开小 会报错。

#include<stdio.h>
int main()
{
	int n,x,y;//分别表示轮数,a 和 b的周期; 
	scanf("%d %d %d",&n,&x,&y);
	int a[300],b[300];//将 a 和 b 的每次出拳记录到数组中去; 
	int sum1=0,sum2=0;//分别表示 a 和 b 的赢得次数; 
	for(int i=0;i<x;i++)
	{
		scanf("%d",&a[i]);//输入一个周期里的出拳情况; 
		for(int j=1;j<=n/x+1;j++)
		{
			a[i+j*x]=a[i];//利用周期将一个周期的情况复制到每一个周期里; 
		}//比方说 第一个的出拳要和下一个周期的第一个出拳一样; 
	}
	for(int i=0;i<y;i++)
	{
		scanf("%d",&b[i]);
		for(int j=1;j<=n/y+1;j++)
		{
			b[i+j*y]=b[i];
		}
	}//解释同上面 a 的解释;
	for(int i=0;i<n;i++)
	{
		if((a[i]==5&&b[i]==2)||(a[i]==2&&b[i]==0)||(a[i]==0&&b[i]==5))
		{
			sum1++;//判断叠加 b 赢得次数; 
		}
		if((a[i]==2&&b[i]==5)||(a[i]==0&&b[i]==2)||(a[i]==5&&b[i]==0))
		{
			sum2++;//判断叠加 a 赢得次数; 
		}
	}
	if(sum1==sum2)
	{
		printf("draw");//如果赢得次数相同则输出打平; 
	}
	if(sum1>sum2)
	{
		printf("B");//b 赢得多输出B; 
	}
	if(sum1<sum2)
	{
		printf("A");//a 赢得多输出A; 
	}
	return 0; 
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值