17:单词替换
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 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App