P13670 [GCPC 2023] Eszett 题解
P13670 [GCPC 2023] Eszett 题解
题目大意
在以前的德语中,大写字母 'ẞ' 通常被写作 'SS'。 如果给定的大写单词有一个或多个出现的 'SS' ,这个单词就对应于多个不同的小写单词,因为每个 'SS' 可能是大写的 'ß',也可能是 'ss'。 给定一个大写德语单词,输出所有可能的小写单词。
输入
一个字符串
输出
对应的所有可能的小写字符串
方法
转小写
逐字符转小写
循环字符串的每一个字符,使用tolower()函数将字符转小写。
当然你也可以将每个字符都加上32或一个字符空格。
使用
transform函数transform(s.begin(),s.end(),s.begin(),::tolower);
transform函数可以将string字符串的每个字符都进行转大写、转小写等操作。替换
既然题目已经提到使用字符串来做本题,C++ 中有一个数据类型,叫
string。string有一个函数,叫replace。s.replace(pos,n,str);它可以把字符串
s 从索引pos 开始的n 个字符替换为str 。 ::::::info[提示] 使用replace会导致字符串s 内容发生变更,所以需要提前做好备份。 ::::::输出
使用
cout、printf、puts等方法输出。 ::::::warning[警告] 使用printf、puts输出时,需使用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; }