题目:
石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。
一天,小 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;
}