【问题描述】
编写程序将一行英文中指定的字符串替换为另一字符串后输出。注意:查找指定字符串时,大小写无关,而且有可能多次出现。
【输入形式】
先从标准输入中分行输入两个英文字符串(每个字符串不为空,长度不超过20,且字符串中不会出现空格),分别表示被替换的字符串和替换成的字符串,然后在下一行输入一行英文(长度不超过200),行末有回车换行。
【输出形式】
将输入的英文按指定字符串替换后输出到标准输出上,末尾应有一个回车换行。
【样例输入】
th
Hello
This second edition of “The C Programming Language” describes C as defined by the ANSI standard. Modern compilers already support most features of the standard.
【样例输出】
Hellois second edition of “Helloe C Programming Language” describes C as defined by Helloe ANSI standard. Modern compilers already support most features of Helloe standard.
【样例说明】
样例中输入的被替换的字符串为th,由于是大小写无关查找替换,所以下一行英文信息中有四个子串要替换:Th、Th、th和th,分别替换为Hello,其它信息原样输出。
解体思路:将一行英文依次输出,如果不符合替换条件原样输出,如果符合替换条件则输出替换后的。省去了每一处替换时要考虑总字符串长增加还是减小,再进行后面字符整体移动的复杂步骤。
#include<stdio.h>
#include<string.h>
int main()
{
char a[20], b[20], str[200];//a为要查找的字符,b为替换后的
gets(a),gets(b),gets(str);
int num1 = strlen(a);//统计字符串的长度
int num3 = strlen(str);
int i, j, flag=1;
for (i = 0; i < num3; i++)
{
if ((str[i] != a[0])&&(str[i] != a[0]-32)&&(str[i] !=a[0]+32))//字符串的大小写无关查找
printf("%c", str[i]);//若不是,按照原来的输出
else{
flag=1;
for (j = 0; j < num1; j++)//对比a与str中的一段是否完全相同
{
if ((str[i+j] != a[j])&&(str[i+j] != a[j]+32)&&(str[i+j] != a[j]-32))
{
flag = 0;
break;
}
}
if (flag)//如果相同,则输出b,完成替换
{
printf("%s",b);
i = i + num1;
i--;
}
else//如果不相同,按照原来的输出
printf("%c", str[i]);
}
}
return 0;
}