Newguy


私信TA

用户名:772007765

访问量:82163

签 名:

已秃人士

等  级
排  名 28
经  验 14606
参赛次数 3
文章发表 92
年  龄 0
在职情况 在职
学  校
专  业

  自我简介:

TA的其他文章

隐匿踪迹
浏览:398
蓝桥杯算法提高VIP-产生数
浏览:957
游花园
浏览:939

描述

输入一个字符串,以回车结束(字符串长度<=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;
}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区

发错了,应该是:
#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;
}
2019-02-13 10:02:54
不对,应该是:
#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;
}
2019-02-13 10:01:38
  • «
  • 1
  • »