题目
思路
这道题直接模拟即可,有两个字符串操作需要注意:
比如有两个字符串 s , s s s,ss s,ss
- 删除 s . e r a s e ( s.erase( s.erase( 起始位置 , , , 往后删几个位置 ) ) )
- 插入 s . i n s e r t ( s.insert( s.insert( 起始位置 , s s ) ,ss) ,ss)
代码
/==============/
由于数据问题,此程序在Ybtoj只能得九十分。
但是在原题上此程序能通过所有点。
/==============/
#include<iostream>
#include<cstring>
#include<string>
#include<cmath>
using namespace std;
string s,ss,newi;
int main()
{
getline(cin,s);
cin>>ss>>newi;
for(int i=0; i<=s.size()-1; i++)
{
if(ss[0]==s[i])
{
int js=0,j=i;
while(ss[js]==s[j]&&js<ss.size()&&j<s.size())
js++,j++;
if(js==ss.size()&&(s[j]==' '||j==s.size())&&(s[i-1]==' '||i==0))
s.erase(i,ss.size()),s.insert(i,newi);
}
}
cout<<s;
return 0;
}