问题标题: 酷町堂:快来人!!!!!!!!!!!!

0
0
已解决
汪宇航
汪宇航
新手启示者
新手启示者

3076   生活大爆炸版石头剪刀布

经验值:400 时间限制:1000毫秒

全国 2014 NOIP 提高组试题

不许抄袭,一旦发现,直接清空经验!

题目描述 Description

石头剪刀布是常见的猜拳游戏:石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一 样,则不分胜负。在《生活大爆炸》第二季第 8 集中出现了一种石头剪刀布的升级版游戏。 升级版游戏在传统的石头剪刀布游戏的基础上,增加了两个新手势:

斯波克:《星际迷航》主角之一。 蜥蜴人:《星际迷航》中的反面角色。

这五种手势的胜负关系如下图所示,表中列出的是甲对乙的游戏结果。
image.png
现在,小 A 和小 B 尝试玩这种升级版的猜拳游戏。已知他们的出拳都是有周期性规律的,但周期长度不一定相等。例如:如果小 A 以“石头-布-石头-剪刀-蜥蜴人-斯波克”长度 为 6 的周期出拳,那么他的出拳序列就是“石头-布-石头-剪刀-蜥蜴人-斯波克-石头-布-石头-剪刀-蜥蜴人-斯波克-……”,而如果小 B 以“剪刀-石头-布-斯波克-蜥蜴人”长度为 5 的周 期出拳,那么他出拳的序列就是“剪刀-石头-布-斯波克-蜥蜴人-剪刀-石头-布-斯波克-蜥蜴人-……”

已知小 A 和小 B 一共进行 N 次猜拳。每一次赢的人得 1 分,输的得 0 分;平局两人都 得 0 分。现请你统计 N 次猜拳结束之后两人的得分。

输入描述 Input Description

第一行包含三个整数:N,NA,NB,分别表示共进行 N 次猜拳、小 A 出拳的周期长度, 小 B 出拳的周期长度。数与数之间以一个空格分隔。

 

 

样例爆了................................

 

 

 

 

#include <bits/stdc++.h>
using namespace std;
int n,na,nb,a[105],b[105],ca,cb;
int ch(char x,char y){
    if(x==0&&y==1||x==1&&y==2||x==2&&y==3||x==3&&y==4||x==4&&y==0)return 1;
    else if(y==0&&x==1||y==1&&x==2||y==2&&x==3||y==3&&x==4||y==4&&x==0)return 2;
    if(x==0&&y==3||x==1&&y==3||x==2&&y==4)return 1;
    else if(x==0&&y==4||x==1&&y==4||x==2&&y==3)return 2;
    if(x==y)return 3;
}
int main(){
    cin>>n>>na>>nb;
    for(int i=1;i<=na;i++){
        cin>>a[i];
    }
    a[0]=a[na];
    for(int i=1;i<=nb;i++){
        cin>>b[i];
    }
    b[0]=b[nb];
    for(int i=1;i<=n;i++){
        if(ch(a[i%na],b[i%nb])==1)ca++;
        else if(ch(a[i%na],b[i%nb])==2)cb++;
    }
    cout<<ca<<' '<<cb;
    return 0;
}

第二行包含 NA 个整数,表示小 A 出拳的规律,第三行包含 NB 个整数,表示小 B 出拳 的规律。其中,0 表示“剪刀”,1 表示“石头”,2 表示“布”,3 表示“蜥蜴人”, 4 表示 “斯波克”。数与数之间以一个空格分隔。

输出描述 Output Description

输出一行, 包含两个整数,以一个空格分隔,分别表示小 A、小 B 的得分。

样例输入 Sample Input

输入样例1: 10 5 6 0 1 2 3 4 0 3 4 2 1 0 输入样例2: 9 5 5 0 1 2 3 4 1 0 3 2 4

样例输出 Sample Output

输出样例1: 6 2 输出样例2: 4 4

数据范围及提示 Data Size & Hint

对于 100%的数据,0 < N ≤ 200,0 < NA ≤ 200, 0 < NB ≤ 200。


0
已采纳
赵睿泽
赵睿泽
资深守护
资深守护

核心代码
for(int i=1;i<=x;i++) cin>>a[i];
for(int i=1;i<=y;i++) cin>>b[i];
for(int i=1;i<=n;i++){
    cnta+=map[a[i%x]][b[i%y]];
    cntb+=map[b[i%y]][a[i%x]];
}

0
0
张展嘉
张展嘉
新手天翼
新手天翼
bool check(int x,int y){
    if(x==0&&y==2||x==0&&y==3||x==1&&y==3||x==2&&y==4||x==3&&y==4||x==1&&y==0||x==2&&y==1||x==3&&y==2||x==4&&y==0||x==4&&y==1){
        return true;
    }
    return false;
}

函数

 for(int i=1;i<=n;i++){
        int x=a[(i-1)%na];
        int y=b[(i-1)%nb];
        if(check(x,y)){
            ca++;
        }
        if(check(y,x)){
            cb++;
        }
    }
    cout<<ca<<' '<<cb;

 

0
0
潘艺博
潘艺博
初级天翼
初级天翼

@汪宇航,康康:

int f(int x,char y)-->我写的

Accepted:100分?

你其他的基本都可以从课堂练习中复制粘贴(这是最快方法)

函数条件:x==0&&y==2||x==0&&y==3||x==1&&y==3||x==2&&y==4||x==3&&y==4||x==1&&y==0||x==2&&y==1||x==3&&y==2||x==4&&y==0||x==4&&y==1

潘艺博在2021-07-17 09:58:25追加了内容

另外一个y就是反过来的

潘艺博在2021-07-17 10:00:42追加了内容

后面x和y好像看不见,是:

x==3&&y==2||x==4&&y==0||x==4&&y==1

我要回答