描述

输入一个字符串,以回车结束(字符串长度<=100)。该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写。现需要将其中的某个单词替换成另一个单词,并输出替换之后的字符串。

输入

多组数据。每组数据输入包括3行,


第1行是包含多个单词的字符串 s,


第2行是待替换的单词a,(长度<=100)


第3行是a将被替换的单词b。(长度<=100)




s, a, b 最前面和最后面都没有空格。

输出

每个测试数据输出只有 1 行,


将s中所有单词a替换成b之后的字符串。

样例输入1

I love Tian Qin
I
You

样例输出1

You love Tian Qi

#include <stdio.h>
#include <string.h>
int main()
{
	char s[200],a[200],b[200];

	while (gets(s))
	{
		int lens=strlen(s),lena;
		int i;

		scanf("%s%s",a,b);
		getchar();               //记得处理换行符
		lena=strlen(a);
		for (i=0;s[i];i++)
		{
			if (!strncmp(&s[i],a,lena))
			{
				printf("%s",b);
				i+=lena-1;
			}
			else
				putchar(s[i]);
		}
		printf("\n");
	}
	return 0;
}


点赞(6)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 2 条评论

炸弹 5年前 回复TA
发错了,应该是:
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
    char s[100],a[100],b[100];
    gets(s);
    int lens=strlen(s),lena;
    int i;
    gets(a);
    gets(b);             
    lena=strlen(a);
    for (i=0;i<lens;)
    {
        if ((strncmp(&s[i],a,lena)==0&&s[i-1]==' '&&s[i+lena]==' ')||
        (strncmp(&s[i],a,lena)==0&&i==0)||
        (strncmp(&s[i],a,lena)==0&&i==lens-lena))
        {
            cout<<b;
            i+=lena;
        }
        else
        {
        	putchar(s[i]);
			i++;
		}
    }
    return 0;
}
炸弹 5年前 回复TA
不对,应该是:
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
    char s[100],a[100],b[100];
    gets(s);
    int lens=strlen(s),lena;
    int i;
    gets(a);
    gets(b);             
    lena=strlen(a);
    for (i=0;i<lens;)
    {
        if ((strncmp(&s[i],a,lena)==0&&s[i-1]==' '&&s[i+lena]==' ')||(strncmp(&s[i],a,lena)==0&&i==0)||(strncmp(&s[i],a,lena)==0&&i==lens-lena))
        {
            cout<<b;
            i+=lena;
        }
        else
        {
        	putchar(s[i]);
			i++;
		}
    }
    return 0;
}