输入描述:
多组数据。每组数据输入包括3行, 第1行是包含多个单词的字符串 s, 第2行是待替换的单词a,(长度<=100) 第3行是a将被替换的单词b。(长度<=100) s, a, b 最前面和最后面都没有空格.
输出描述:
每个测试数据输出只有 1 行, 将s中所有单词a替换成b之后的字符串。
示例1
输入
You want someone to help you You I
输出
I want someone to help you
/* 解题思路:先将s分成各个单词,将每个单词存在向量中,然后取出向量中的元素,逐个与a比较,若相等则替换输出。 注: istream& getline ( istream &is , string &str , char delim ); 其中 istream &is 表示一个输入流,譬如cin; string&str表示把从输入流读入的字符串存放在这个字符串中(可以自己随便命名,str什么的都可以); char delim表示遇到这个字符停止读入,在不设置的情况下系统默认该字符为'\n',也就是回车换行符(遇到回车停止读入)。 */
#include<iostream>
#include<string>
#include<vector>
using namespace std;
int main()
{
int flag = 0;
string s,a,b;
vector<string>words; //用来保存各个单词
vector<string>switch; //用来保存各个单词
getline(cin,s); //为了接受一行带空格的字符串
cin>>a>>b;
//将s中的单词提取到words
for(int i=0,j=0;i<s.size();++i){
if(s[i]!=' ')
words[j] += s[i];
else{
++j;
}
}
for(int i=0;i<words.size();++i)
{ //找到第一个要替换的单词并替换
if((0 == strcmp(words[i],a)) &&(0 == flag))
{
switch.push(b);
flag++
}//将单词放到switch
else
{
switch.push(words[i]);
}
}
for(int i=0;i<switch.size();++i)
{ //输出
cout<<switch[i]<<" ";
}
return 0;
}