算法笔记(入门篇1-入门模拟)--字符串处理--问题 D: 单词替换

问题 D: 单词替换

时间限制: 1 Sec  内存限制: 32 MB

题目描述

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

输入

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

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

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

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

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

输出

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

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

样例输入

I love Tian Qin
I
You

样例输出

You love Tian Qin
#include<stdio.h>
#include<string.h>
int main()
{
    char arr[101][101],a[101],b[101];
    int i,j;
    while(scanf("%s",arr[0])!=EOF)
    {
        i=1;
        while(getchar()!='\n')
            scanf("%s",arr[i++]);

        scanf("%s",a);
        scanf("%s",b);

        //找出单词并替换
        for(j=0; j<i-1; j++)
        {
            if(strcmp(a,arr[j])==0)//说明相等
            {
                printf("%s ",b);
            }
            else
            {
                printf("%s ",arr[j]);
            }
        }
        if(strcmp(a,arr[j])==0)//说明相等
        {
            printf("%s ",b);
        }
        else
        {
            printf("%s ",arr[j]);
        }
        printf("\n");
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/syd1091245120/article/details/81544666