P13670 [GCPC 2023] Eszett 题解

· · 题解

P13670 [GCPC 2023] Eszett 题解

题目大意

在以前的德语中,大写字母 'ẞ' 通常被写作 'SS'。 如果给定的大写单词有一个或多个出现的 'SS' ,这个单词就对应于多个不同的小写单词,因为每个 'SS' 可能是大写的 'ß',也可能是 'ss'。 给定一个大写德语单词,输出所有可能的小写单词。

输入

一个字符串 s

输出

对应的所有可能的小写字符串 s

方法

转小写

逐字符转小写

循环字符串的每一个字符,使用tolower()函数将字符转小写。

当然你也可以将每个字符都加上32或一个字符空格。

使用transform函数

transform(s.begin(),s.end(),s.begin(),::tolower);

transform函数可以将string字符串的每个字符都进行转大写、转小写等操作。

替换

既然题目已经提到使用字符串来做本题,C++ 中有一个数据类型,叫stringstring有一个函数,叫replace

s.replace(pos,n,str);

它可以把字符串 s 从索引 pos 开始的 n 个字符替换为 str。 ::::::info[提示] 使用replace会导致字符串 s 内容发生变更,所以需要提前做好备份。 ::::::

输出

使用coutprintfputs等方法输出。 ::::::warning[警告] 使用printfputs输出时,需使用c_str()把字符串转成 C 风格的,再输出 :::::: ::::::info[提示] 题目是 Special Judge 的,输出顺序可以改变 ::::::

代码实现

#include<bits/stdc++.h>//万能头文件
using namespace std;
int main()
{
string s;//定义字符串
cin>>s;//输入
transform(s.begin(),s.end(),s.begin(),::tolower);
//转小写
puts(s.c_str());//自己就是一种方案
for(int i=0;s[i];i++)
{
if(s[i]=='s'&&s[i+1]=='s')//有'ss'
{
string c=s;//备份
c.replace(i,2,"B");//将'ss'替换为'B'
puts(c.c_str());//输出
}
}
return 0;
}