描述
输入一个字符串,以回车结束(字符串长度<=100)。该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写。现需要将其中的某个单词替换成另一个单词,并输出替换之后的字符串。
输入
输入包括3行,
第1行是包含多个单词的字符串 s;
第2行是待替换的单词a(长度 <= 100);
第3行是a将被替换的单词b(长度 <= 100).
s, a, b 最前面和最后面都没有空格.
输出
输出只有 1 行,将s中所有单词a替换成b之后的字符串。
样例输入
You want someone to help you You I
样例输出
I want someone to help you
#include<bits/stdc++.h>
using namespace std;
#define N 105
int main()
{
string s, words[N], oriWord, tarWord;
int i = 0, wordNum;
while(cin >> s)//每次将一个单词读入words[i],而后i指向下一个位置,直到没有单词为止。
words[i++] = s;
tarWord = words[i-1];//最后两个单词为要被替换的单词与替换后的单词
oriWord = words[i-2];
wordNum = i - 2;//单词总数
for(int i = 0; i < wordNum; ++i)
{
if(oriWord == words[i])//如果oriWord与第i个单词相同
words[i] = tarWord; //把第i个单词替换为tarWord
}
for(int i = 0; i < wordNum; ++i)
cout << words[i] << ' ';
return 0;
}