#include <iostream>
using namespace std;
void func()
{
while(1){
char str[10][20];
char f[200];
char s[20];
char d[20];
if(gets(f)==NULL)break;;
gets(s);
gets(d);
char *q=strtok(f," ");
int word=0;
int i;
while(q!=NULL){
//printf("%s\n",q);
strcpy(str[word],q);
q=strtok(NULL," ");
word++;
}
// printf("%d\n",word);
for(i=0;i<word-1;i++)
{
if(strcmp(str[i],s)==0)
printf("%s ",d);
else
printf("%s ",str[i]);
}
if(strcmp(str[i],s)==0)
printf("%s\n",d);
else
printf("%s\n",str[i]);
}
}
int main(int argc, char *argv[])
{
//printf("Hello, world\n");
func();
return 0;
}
我的处理方式是先把单词分解出来,比较费时
最好匹配一个输出一个
-
题目描述:
-
输入一个字符串,以回车结束(字符串长度<=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