题目地址


注意点:

  • 可以直接用{}初始化数组.

#include<cstdio>
#include<iostream>
using namespace std;
const int MAXN=2e3;
int isWin[12][12]={
{0,-1,1,1,-1},
{1,0,-1,1,-1},
{-1,1,0,-1,1},
{-1,-1,1,0,1},
{1,1,-1,-1,0}};//[玩家a][玩家b] -1:玩家a输 , 0:平局, 1:玩家a赢 
int a[MAXN],b[MAXN];//小A 小B的出拳规律
int main(){
	int n,na,nb;
	scanf("%d%d%d",&n,&na,&nb);
	for(int i=1;i<=na;i++){
		scanf("%d",&a[i]);
	}
	for(int i=1;i<=nb;i++){
		scanf("%d",&b[i]);
	}
	int nowUseA=1,nowUseB=1;//A B当前出哪个拳
	int ansA=0,ansB=0;//A B的得分 
	for(int i=1;i<=n;i++){//n次猜拳 
		if(nowUseA>na)nowUseA=1;
		if(nowUseB>nb)nowUseB=1;
		int ans=isWin[a[nowUseA]][b[nowUseB]];//A是否胜利
		if(ans==1){//胜利 
			ansA++;
		}else if(ans==-1){//失败 
			ansB++;
		}
		nowUseA++,nowUseB++;
	} 
	printf("%d %d\n",ansA,ansB);
	return 0;
}