PTA 7-29 删除字符串中的子串(20 分)strstr函数应用

7-29 删除字符串中的子串(20 分)

输入2个字符串S1和S2,要求删除字符串S1中出现的所有子串S2,即结果字符串中不能包含S2。

输入格式:

输入在2行中分别给出不超过80个字符长度的、以回车结束的2个非空字符串,对应S1和S2。

输出格式:

在一行中输出删除字符串S1中出现的所有子串S2后的结果字符串。

输入样例:

Tomcat is a male ccatat
cat

输出样例:

Tom is a male
这道题如果不用strstr函数会比较麻烦,我开始想用find函数,但是find函数的返回值我不太会处理,就改用strstr--查找子串函数,返回值是char *类型的,运用比较灵活、快捷
#include<bits/stdc++.h>
using namespace std;
int main()
{
    char a[81];char b[81];char c[81];
	char *p;
    gets(a);
    gets(b);
    while((p=strstr(a,b))!=NULL)//strstr找不到返回NULL
	{  
        *p='\0';//将字符串a隔断 
        strcpy(c,p+strlen(b));  
        strcat(a,c);//strcat函数中的两个传入参数的内存地址不能重叠 
    } 
    puts(a);
    return 0;
} 

测试点全部通过,简单快捷


猜你喜欢

转载自blog.csdn.net/hebau_pss/article/details/79560449