联想算法题-石头剪刀布

联想算法题-石头剪刀布

问题描述
剪刀石头布是一种常见的猜拳游戏,当玩家人数为两人时,它的规则如下:在每一轮中,双方分别同时给出石头(Rock)、剪刀(Scissor)和布(Paper)这三种手势中的一种。石头战胜剪刀;剪刀战胜布;布战胜石头。若双方给出的手势一样则本轮平局,双方分数不变;否则胜方积1分。
现在Alice和Bob想进行若干轮猜拳游戏,但他们不想逐轮进行游戏,于是决定分别在纸上写下他们每一轮要出的手势。作为裁判的你需要根据他们所写下的手势判断他们的比分是多少。
输入描述
第一行是一个正整数T,表示他们想进行的轮数。
第二行包含T个空格隔开的字符串s_1, s_2, …, s_T,其中s_i表示Alice写下的第i轮要出的手势。
第三行包含T个空格隔开的字符串t_1, t_2, …, t_T,其中t_i表示Bob写下的第i轮要出的手势。
所有的s_i和t_i均是”Rock”,”Scissor”,”Paper”中的一种。

输出描述
输出两个用空格隔开的整数x y,其中x表示Alice的得分,y表示Bob的得分。

输入样例1
3
Rock Rock Rock
Rock Paper Scissor

输出样例1
1 1

数据范围和说明
30%的数据保证:3<=T<=10
80%的数据保证:3<=T<=100
100%的数据保证 :3<=T<=500

算法思路:

这个题的思路模拟,简单的过程模拟

#include<iostream>
using namespace std;
#include<vector>

int main()
{
    int t;
    cin >> t;
    vector<string> a;
    vector<string> b;
    string str;
    int res1 = 0;
    int res2 = 0;
    for (int i = 0; i < t; ++ i)    
    {
        cin >> str;
        a.push_back(str);
    }
    for (int i = 0; i < t; ++ i)    
    {
        cin >> str;
        b.push_back(str);
    }
    for (int i = 0; i < t; ++ i)
    {
        if (a[i] == b[i]) continue;
        else if (a[i] == "Rock" && b[i] == "Paper") res2 ++;
        else if (a[i] == "Scissor" && b[i] == "Rock") res2 ++;
        else if (a[i] == "Paper" && b[i] == "Scissor") res2 ++;
        else res1 ++;
    }
    cout << res1 << " " << res2;
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

极客李华

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值