5603: 教师培训C++第三十二题 文字处理软件 LG

Memory Limit:128 MB Time Limit:1.000 S
Judge Style:Text Compare Creator:
Submit:1 Solved:1

Description

你需要开发一款文字处理软件。最开始时输入一个字符串作为初始文档。可以认为文档开头是第 0 个字符。需要支持以下操作:

  • 1 str:后接插入,在文档后面插入字符串 str,并输出文档的字符串;
  • 2 a b:截取文档部分,只保留文档中从第a 个字符起b 个字符,并输出文档的字符串;
  • 3 a str:插入片段,在文档中第a 个字符前面插入字符串 str,并输出文档的字符串;
  • 4 str:查找子串,查找字符串 strstr 在文档中最先的位置并输出;如果找不到输出 −1

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

Input

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

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

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

Output

一共输出q 行。

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

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

Sample Input Copy

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

Sample Output Copy

ILoveLuogu
Luogu
LuoguGugugu
3

HINT

数据保证,1q100,开始的字符串长度 100