石头剪刀布
石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。
一天,小 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代码,希望给小伙伴们有帮助。