0
点赞
收藏
分享

微信扫一扫

计蒜客石头剪刀布 纯C

书坊尚 2022-01-04 阅读 39

石头剪刀布

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

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

输入格式

输入包含三行。

第一行包含三个整数:NNN,NANANA,NBNBNB,分别表示比了 NNN 轮,小 AAA 出拳的周期长度,小 BBB 出拳的周期长度。0<N,NA,NB<1000 < N,NA,NB < 1000<N,NA,NB<100。

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

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

其中,000 表示“石头”,222 表示“剪刀”,555 表示“布”。相邻两个整数之间用单个空格隔开区域中间;

输出格式

输出一行,如果小 AAA 赢的轮数多,输出"A";如果小 BBB 赢的轮数多,输出"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 轮,BBB 赢了 2 轮,双方打平 4 轮,所以 A 赢的轮数多。

思路;重点是给了A、B两人的出拳周期,所以只需要在题目给定的周期里面,重复A、B周期出拳来进行比较即可,重点在于重置A、B两人数组的下标。`

#include<stdio.h>
int main(){
	int i,j,k,n,m,c,e=0,g=0;
	int a[105],b[105];
	scanf("%d %d %d",&n,&m,&c);
	for( i=0;i<m;i++)
	{	
		scanf("%d",&a[i]);
	}
	for(j=0;j<c;j++)
	{
		scanf("%d",&b[j]);
	}
i=0;j=0;k=1;
	while(k<=n)
	{
		if(a[i]==0&&b[j]==2||a[i]==2&&b[j]==5||a[i]==5&&b[j]==0)
			e++;
		if(b[j]==0&&a[i]==2||b[j]==2&&a[i]==5||b[j]==5&&a[i]==0)
			g++;
		i++;
		if(i>=m)
			i=0;        //重置下标
		j++;
		if(j>=c)
			j=0;
		k++;
	}
	if(e>g)
		printf("A");
	if(e==g)
		printf("draw");
	if(e<g)
		printf("B");
	return 0;
}

提示

这个是我在做计蒜客题库时的经验,借鉴了大佬的C++的代码所总结的纯C代码,希望给小伙伴们有帮助。

举报

相关推荐

石头剪刀布

c++石头剪刀布游戏

C#的剪刀石头布

石头剪刀布游戏(C语言)

计蒜客练习

0 条评论