Hello 大家好我是小亦今天也是又来更新题解了好吧在这里呢也是感谢大家的支持哈🦐那今天我们讲的是关于在洛谷网站上的一场比赛BP11034 【MX-X3-T1】「RiOI-4」What beats RiOI话不多说直接来看思路#^.^#:
这道题一看就是模拟和字符串嘛,那下面我来分析一下吧
-
定义子串:首先,我们需要确定要检查的子串,这里是 "RiOI" 或 "rioi"。
-
忽略大小写:由于检查时不区分大小写,我们需要将输入的字符串转换为全小写或全大写,以便于比较。
-
检查子串:使用字符串查找函数(如 C++ 中的
std::string::find
)来检查转换后的字符串是否包含目标子串 "rioi"。 -
设计函数:创建一个函数
isShiny
,它接受一个字符串作为参数,并返回一个布尔值,表示该字符串是否包含子串 "rioi"。 -
读取输入:读取两个字符串
s
和t
。 -
应用函数:对两个字符串分别调用
isShiny
函数。 -
逻辑判断:
- 如果两个字符串都是好闪的(即
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;
}