一、题目
二、解题思路
- 通过 substr() 根据位置得到子串;
- 通过 erase() 将子串从原字符串中删除;
- 通过 find() 查看新的字符串中是否有 str1+str2 ,有的话返回首次出现的位置,否则返回 -1 ;
- 若没有则通过 str+=t 将子串粘贴到字符串末尾;
- 有的话则粘贴到 str1,str2之间。
三、代码
#include<iostream>
using namespace std;
int main()
{
string str;
cin>>str;
int n;
cin>>n;
while(n--)
{
int a,b;
string str1,str2;
cin>>a>>b>>str1>>str2;
string t=str.substr(a-1,b-a+1);
str.erase(a-1,b-a+1);
int pos1=str.find(str1+str2);
int pos2=pos1+str1.length();
if(pos1==-1)
{
str+=t;
}
else
{
str=str.substr(0,pos1)+str1+t+str.substr(pos2,str.length()-pos2);
}
}
cout<<str<<endl;
}
四、总结
对字符串方法的应用:substr() , erase() ,find() 。