17:单词替换

简介: 17:单词替换    总时间限制:1000ms 内存限制:65536kB描述    输入一个字符串,以回车结束(字符串长度

17:单词替换
    总时间限制:1000ms 内存限制:65536kB
描述
    输入一个字符串,以回车结束(字符串长度<=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

 

思路:把三个串分别输入到s、a、b。然后扫描s,每当发现一个单词就把该单词放到t串。当该单词结束,

比较t串和a串是否一致,若a==t则输出b,否则输出t。扫描时遇到空格要注意区分该空格是表示当前

单词还没开始或是当前单词已经结束(可以输出该单词)

 1 #include<stdio.h>
 2 #include<string.h>
 3 int main(int argc, char *argv[])
 4 {
 5     char s[105],a[105],b[105],t[105];
 6     int i;
 7     int f;
 8     int j;
 9     freopen("17.in","r",stdin);
10     gets(s);
11     scanf("%s",a);
12     scanf("%s",b);
13     
14     i=0;
15     f=0;// f=0表示还没开始一个单词 
16     j=0;
17     while(s[i]!='\0')
18     {
19         if(s[i]==' ') 
20         {
21             if(f==0)
22                 printf(" ");
23             else if(f==1) // f=1表示一个单词扫描结束 
24             {
25                 t[j]='\0';
26                 if(strcmp(t,a)==0) printf("%s",b);
27                 else printf("%s",t);
28                 j=0;
29                 printf(" ");
30                 f=0;
31             }
32         }
33         else
34         {
35             t[j]=s[i];
36             j++;
37             f=1;
38         }
39         i++;
40     }
41     //处理末尾单词 
42     t[j]='\0';
43     if(strcmp(t,a)==0) printf("%s",b);
44     else printf("%s",t);
45     return 0;
46 }

 

相关文章
|
6月前
字符串\单词本管理
字符串\单词本管理
29 1
|
7月前
|
索引 Python
字符串:比较、拼接、切割、转义字符;相关切割、替换、查找、去除空白、转大小写函数的方法
字符串:比较、拼接、切割、转义字符;相关切割、替换、查找、去除空白、转大小写函数的方法
44 0
|
7月前
|
Unix Perl
`sed`命令替换文本中的单词
`sed`命令替换文本中的单词
162 3
|
7月前
leetcode-2000:反转单词前缀
leetcode-2000:反转单词前缀
50 0
leetcode-2000:反转单词前缀
|
Python
python字符串切分连接(输入一个包含多个单词的英文句子,单词间以空格分隔,标点符号后跟一个空格。定义一个函数,功能是用指定的符号把单词连接起来。)
python字符串切分连接(输入一个包含多个单词的英文句子,单词间以空格分隔,标点符号后跟一个空格。定义一个函数,功能是用指定的符号把单词连接起来。)
1092 0
LeetCode 5867. 反转单词前缀
给你一个下标从 0 开始的字符串 word 和一个字符 ch 。找出 ch 第一次出现的下标 i ,反转 word 中从下标 0 开始、直到下标 i 结束(含下标 i )的那段字符。
87 0
|
算法 Java 索引
【算法】给定一个字符串 s 和一些长度相同的单词 words,串联所有单词的子串。要不要来试一试?
给定一个字符串 s 和一些长度相同的单词 words串联所有单词的子串
155 0
【算法】给定一个字符串 s 和一些长度相同的单词 words,串联所有单词的子串。要不要来试一试?
|
存储 算法
算法:编程在一个已知的字符串中查找最长单词,假定字符串中只包含字母和空格,空格用来分隔不同单词
算法:编程在一个已知的字符串中查找最长单词,假定字符串中只包含字母和空格,空格用来分隔不同单词
LeetCode 524. 通过删除字母匹配到字典里最长单词
LeetCode 524. 通过删除字母匹配到字典里最长单词
77 0