P5734 【深基6.例6】文字处理软件

题目描述

你需要开发一款文字处理软件。最开始时输入一个字符串作为初始文档。可以认为文档开头是第 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-11

为了简化问题,规定初始的文档和每次操作中的 str\texttt{str}str 都不含有空格或换行。最多会有 qqq 次操作。

输入格式

第一行输入一个正整数 qqq,表示操作次数。

第二行输入一个字符串 str\texttt{str}str,表示最开始的字符串。

第三行开始,往下 qqq 行,每行表示一个操作,操作如题目描述所示。

输出格式

一共输出 qqq 行。

对于每个操作 1,2,31,2,31,2,3,根据操作的要求输出一个字符串。

对于操作 444,根据操作的要求输出一个整数。

输入输出样例 #1

输入 #1

4
ILove
1 Luogu
2 5 5
3 3 guGugu
4 gu

输出 #1

ILoveLuogu
Luogu
LuoguGugugu
3

说明/提示

数据保证,1≤q≤1001 \leq q\le 1001q100,开始的字符串长度 ≤100\leq 100100

#include<cstdio>
#include<iostream>
#include<string>
using namespace std;
string s,s1;
int q,op,a,b;
int main()
{
	scanf("%d",&q);
	cin>>s;
	while(q--)
	{
		scanf("%d",&op);
		if(op==1)
		{
			cin>>s1;
			s+=s1;
			cout<<s<<endl;
		}
		else if(op==2)
		{
			scanf("%d%d",&a,&b);
			s=s.substr(a,b);
			cout<<s<<endl;
		}
		else if(op==3)
		{
			scanf("%d",&a);
			cin>>s1;
			s.insert(a,s1);
			cout<<s<<endl;			 
		}
		else
		{
			cin>>s1;
			cout<<(int)s.find(s1)<<endl; 
			
		}
	}
	return 0;
} 

这个代码中,string类型,一律用cin>>进行输入 ,比较 方便。

Logo

集算法之大成!助力oier实现梦想!

更多推荐