(洛谷)【MX-J4】梦熊 J 组 · 面包赛 & RiOI Round 4(同步赛)题目BP11034 【MX-X3-T1】「RiOI-4」What beats RiOI题解

Hello 大家好我是小亦今天也是又来更新题解了好吧在这里呢也是感谢大家的支持哈🦐那今天我们讲的是关于在洛谷网站上的一场比赛BP11034 【MX-X3-T1】「RiOI-4」What beats RiOI话不多说直接来看思路#^.^#:

这道题一看就是模拟和字符串嘛,那下面我来分析一下吧

  1. 定义子串:首先,我们需要确定要检查的子串,这里是 "RiOI" 或 "rioi"。

  2. 忽略大小写:由于检查时不区分大小写,我们需要将输入的字符串转换为全小写或全大写,以便于比较。

  3. 检查子串:使用字符串查找函数(如 C++ 中的 std::string::find)来检查转换后的字符串是否包含目标子串 "rioi"。

  4. 设计函数:创建一个函数 isShiny,它接受一个字符串作为参数,并返回一个布尔值,表示该字符串是否包含子串 "rioi"。

  5. 读取输入:读取两个字符串 st

  6. 应用函数:对两个字符串分别调用 isShiny 函数。

  7. 逻辑判断

    • 如果两个字符串都是好闪的(即 isShiny(s) 和 isShiny(t) 都返回 true),输出 "Either is ok!"。
    • 如果只有 s 是好闪的,输出 "s for sure!"。
    • 如果只有 t 是好闪的,输出 "t for sure!"。
    • 如果两个字符串都不是好闪的,输出 "Try again!"。

                以上呢是我的个人思路如果有误就私信哈,再次话不多说代码供上

#include <iostream>
#include <string>
#include <algorithm>

// 检查字符串是否包含子串 "RiOI" 或 "rioi",不区分大小写
bool isShiny(const std::string& s) {
    std::string lower_s = s;
    std::transform(lower_s.begin(), lower_s.end(), lower_s.begin(), ::tolower);
    return lower_s.find("rioi") != std::string::npos;
}

int main() {
    std::string s, t;
    std::cin >> s >> t;

    if (isShiny(s) && isShiny(t)) {
        std::cout << "Either is ok!" << std::endl;
    } else if (isShiny(s) && !isShiny(t)) {
        std::cout << s << " for sure!" << std::endl;
    } else if (!isShiny(s) && isShiny(t)) {
        std::cout << t << " for sure!" << std::endl;
    } else {
        std::cout << "Try again!" << std::endl;
    }

    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值