【题目描述】
输入一个字符串,以回车结束(字符串长度≤200)。该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写。现需要将其中的某个单词替换成另一个单词,并输出替换之后的字符串。
【输入】
第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<iostream>
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;
}