描述
输入一个字符串,以回车结束(字符串长度<=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 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发错了,应该是: #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; }不对,应该是: #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; }