输入2个字符串S1和S2,要求删除字符串S1中出现的所有子串S2,即结果字符串中不能包含S2。
输入格式:
输入在2行中分别给出不超过80个字符长度的、以回车结束的2个非空字符串,对应S1和S2。
输出格式:
在一行中输出删除字符串S1中出现的所有子串S2后的结果字符串。
输入样例:
Tomcat is a male ccatat
cat
输出样例:
Tom is a male
代码:
#include <stdio.h>
#include <string.h>
int main(void)
{
char s1[100],s2[100];//我本来想用80就够了的,结果显示运行时错误,哎,那就改成100吧
gets(s1);
gets(s2);
char s3[100],*p;//s3放重复子串后面的字符串,p放重复子串的地址
while((p=strstr(s1,s2))!=NULL)//有重复子串
{
strcpy(s3,p+strlen(s2));//存!
*p='\0';//断!
strcat(s1,s3);//粘!
}
puts(s1);//输!
return 0;
}