输入一个字符串,以回车结束(字符串长度不超过 100)。
该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写。
现需要将其中的某个单词替换成另一个单词,并输出替换之后的字符串。
输入格式
输入共 3 行。
第 1 行是包含多个单词的字符串 s;
第 2 行是待替换的单词 a(长度不超过 100);
第 3 行是 a 将被替换的单词 b(长度不超过 100)。
输出格式
共一行,输出将 s 中所有单词 a 替换成 b 之后的字符串。
输入样例:
You want someone to help you
You
I
输出样例:
I want someone to help you
AC
捣鼓了好久,终于把每一个测试点都过去了,题目上面这一个测试点,真的不够啊
但是就在快要写出来的时候,我突然有了新的想法。
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int main()
{
string s,a,b;
getline(cin,s);
getline(cin,a);
getline(cin,b);
for(int i=0;i<s.length();i++){
if(s.substr(i,a.length())==a){
if(s[i-1]==' '&&s[i+a.length()]==' '||i==0||i==s.length()-a.length()){
cout << b;
i=i+a.length()-1;
}
else cout << s[i];
}
else cout << s[i];
}
}
这个方法看起来也不错,我也改了好大一会呢。。。
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int main()
{
string s[100];
int n=0;
while(cin>>s[n++]);
for (int i = 0; i < n-3; i ++ ){
if(i) cout<<" ";
if(s[i]==s[n-3]) cout<<s[n-2];
else cout << s[i];
}
}