题目描述
你需要开发一款文字处理软件。最开始时输入一个字符串作为初始文档。可以认为文档开头是第 000 个字符。需要支持以下操作:
-
1 str:后接插入,在文档后面插入字符串 str\texttt{str}str,并输出文档的字符串。 -
2 a b:截取文档部分,只保留文档中从第 aaa 个字符起 bbb 个字符,并输出文档的字符串。 -
3 a str:插入片段,在文档中第 aaa 个字符前面插入字符串 str\texttt{str}str,并输出文档的字符串。 -
4 str:查找子串,查找字符串 str\texttt{str}str 在文档中最先的位置并输出;如果找不到输出 −1-1−1。
为了简化问题,规定初始的文档和每次操作中的 str\texttt{str}str 都不含有空格或换行。最多会有 qqq 次操作。
输入格式
第一行输入一个正整数 qqq,表示操作次数。
第二行输入一个字符串 str\texttt{str}str,表示最开始的字符串。
第三行开始,往下 qqq 行,每行表示一个操作,操作如题目描述所示。
输出格式
一共输出 nnn 行。
对于每个操作 1,2,31,2,31,2,3,根据操作的要求输出一个字符串。
对于操作 444,根据操作的要求输出一个整数。
样例输入
4
ILove
1 Luogu
2 5 5
3 3 guGugu
4 gu
样例输出
ILoveLuogu
Luogu
LuoguGugugu
3
提示
数据保证,1≤q≤1001 \leq q\le 1001≤q≤100,开始的字符串长度 ≤100\leq 100≤100。
思路分析
本题考查字符串的4个基本操作。题目说明文档开头是第0个字符,这就把字符的序号与下标对应起来了,调用字符串的操作函数时直接传入位置即可。
参考代码
#include<iostream>
#include<string>
using namespace std;
string s,str; //s-第一个字符串,str-每次要处理的字符串
int q;
int main() {
cin >> q;
cin >> s; //字符串中没有空格,可以使用cin读入
while(q--)
{
//op-操作类型(1、2、3、4),a b-与题目中意思一致
int op,a,b;
cin >> op;//读入操作类型
switch(op)
{
case 1:
cin >> str;
s += str; //后接
cout << s << endl;
break;
case 2:
cin >> a >> b;
s = s.substr(a,b); //截取字串
cout << s << endl;
break;
case 3:
cin >> a >> str;
s.insert(a,str); //插入子串
cout << s << endl;
break;
case 4:
cin >> str;
int pos = s.find(str); //找不到时的返回值,赋值给整数变量后,可以得到-1
cout << pos << endl;
}
}
return 0;
}

该文描述了一个C++程序,用于处理字符串的四种基本操作:在末尾插入字符串、截取指定范围的字符串、在指定位置插入字符串以及查找子串。程序通过使用标准库中的string类方法实现这些功能,并对输入的操作进行解析以执行相应操作。
1014

被折叠的 条评论
为什么被折叠?



