题目名称:OpenJ_Bailian-单词替换
题目链接:单词替换
描述
输入一个字符串,以回车结束(字符串长度<=100)。该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写。现需要将其中的某个单词替换成另一个单词,并输出替换之后的字符串。
Input
输入包括3行,
第1行是包含多个单词的字符串 s;
第2行是待替换的单词a(长度 <= 100);
第3行是a将被替换的单词b(长度 <= 100).
s, a, b 最前面和最后面都没有空格.
Output
输出只有 1 行,将s中所有单词a替换成b之后的字符串。
Sample Input
You want someone to help you
You
I
Sample Output
I want someone to help you
解题思路
一开始直接使用string类中的replace函数实现,提示答案错误,看了题解才明白是替换单词而不是字符,所以改成了替换单词
完整代码
#include<iostream>
#include<algorithm>
#include<string>
#include<cstdio>
using namespace std;
string s[110],a,b;
int main()
{
int tot=0;
char ch;
cin>>s[tot++];
while((ch=getchar())!='\n') {
cin>>s[tot++];
}
cin>>a>>b;
for(int i=0;i<tot;i++){
if(s[i]==a){
if(i!=tot-1){
cout<<b<<' ';
}else{
cout<<b<<endl;
}
}else{
if(i!=tot-1){
cout<<s[i]<<' ';
}else{
cout<<s[i]<<endl;
}
}
}
return 0;
}