专栏文章

P13670 [GCPC 2023] Eszett 题解

P13670题解参与者 1已保存评论 0

文章操作

快速查看文章及其快照的属性,并进行相关操作。

当前评论
0 条
当前快照
1 份
快照标识符
@miofeqs5
此快照首次捕获于
2025/12/02 18:19
3 个月前
此快照最后确认于
2025/12/02 18:19
3 个月前
查看原文

P13670 [GCPC 2023] Eszett 题解

题目大意

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

输入

一个字符串 ss

输出

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

方法

转小写

逐字符转小写

循环字符串的每一个字符,使用tolower()函数将字符转小写。
当然你也可以将每个字符都加上32或一个字符空格。

使用transform函数

CPP
 transform(s.begin(),s.end(),s.begin(),::tolower);
transform函数可以将string字符串的每个字符都进行转大写、转小写等操作。

替换

既然题目已经提到使用字符串来做本题,C++ 中有一个数据类型,叫stringstring有一个函数,叫replace
CPP
s.replace(pos,n,str);
它可以把字符串 ss 从索引 pospos 开始的 nn 个字符替换为 strstr
提示
使用replace会导致字符串 ss 内容发生变更,所以需要提前做好备份。

输出

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

代码实现

CPP
#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;
}

评论

0 条评论,欢迎与作者交流。

正在加载评论...