7-5 删除字符串中的子串

输入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()
{
    char a[81],b[81];
    gets(a);
    gets(b);
    char *p;    
    char c[81];
    while(p=strstr(a,b)) 
	{ 
        *p = '\0';  
        strcpy (c, p+strlen(b));  
        strcat (a, c);
    } 
    puts(a);    
    return 0;
}

乍一看是个很难的题目,当你知道<string.h>这个头文件中有巨多好用的函数后,这道题目就简单了不少
strstr(a,b) 检测两个数组重复的部分
strlen(b) 计算字符串长度
strcat (a, c)字符串相加
strcpy (a,b)复制字符串
具体用法自行百度。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 题目描述 给定一个字符串S和一个子串T,在S删除所有T的出现输入格式 第一行输入一个字符串S,长度不超过100。 第二行输入一个子串T,长度不超过10。 输出格式 输出删除后的字符串。 样例输入 They are students. the 样例输出 y are studnts. 算法1 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 Python 代码 算法2 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 C++ 代码 算法3 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 Java 代码 算法4 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 C# 代码 算法5 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 Go 代码 算法6 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 Scala 代码 算法7 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 JavaScript 代码 算法8 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 Ruby 代码 算法9 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 Swift 代码 算法10 (暴力枚举) $O(n^2)$ blablabla 时间复杂度 参考文献 Kotlin 代码 ### 回答2: 题目描述: 给定一个字符串 S 和一个被删除字符串 T,请输出 S 所有满足条件的子串。 我们称 T 是 S 的一个拓扑子序列,若 S 删除若干个字符(也可以不删除)得到的序列恰好是 T。 例如,S = "abbcd",T = "abc",则 T 是 S 的拓扑子序列,因为 S 删除 b 和 d 后得到 "abc"。 输入描述: 两个字符串 S 和 T,且 S 的长度不超过 1000,T 的长度不超过 10。 输出描述: 按字符串的顺序,依次输出 S 所有满足条件的子串,每个子串占一行。如果没有符合条件的子串,则输出一行 ""(不含引号)。 示例: 输入: 7-29输入示例 输出: 7-29输出示例 思路分析: 给定一个字符串S和一个要删除字符串T,求S全部符合条件的子串。 拓扑子序列:一个字符串 S 和一个删除字符串 T,S删除若干个字符(也可以不删除)得到的序列恰好是 T。假设 S = "abbcd",T = "abc",此时 T 是 S 的拓扑子序列,因为 S 删除 b 和 d 后得到 "abc"。 对于一个字符串S,我们可以从左向右遍历,遇到一个字符等于T的第一个字符,就开始判断是否符合条件,直到找到最后一个字符相等或者找到T的最后一个字符(如果出现了不符合条件的字符,则断)。如果是符合条件的,就把对应的子串输出,间的字符不能超过10个。 代码实现: 首先输入字符串S和要删除字符串T,由于有多组输入数据,我们使用while循环来进行多次输入输出。接下来我们从左向右遍历S,遇到一个字符等于T的第一个字符,就开始判断是否符合条件,一直到找到最后一个字符或者找到了T的最后一个字符。如果是符合条件的,就把对应的子串输出。注意,输出所有符合条件的子串之后,需要在最后增加一个空字符串""。 ### 回答3: 这道题目要求我们实现一个函数,删除给定字符串出现的指定子串。可以使用两种方式实现,一种是暴力匹配,一种是KMP算法。 暴力匹配的实现方式是,枚举原始字符串的每一个字符,如果当前字符和要删除子串的第一个字符相等,就比较接下来的字符是否也相等,如果完全匹配,就将该子串删除,然后继续循环匹配,直到找到所有的子串删除完成。 KMP算法的实现方式是,首先针对要删除子串构建一个next数组,指示每个位置上一次匹配失败后应该从哪个位置重新开始匹配。然后对原始字符串进行查找,每次根据next数组的值判断要往后移动的距离,从而能够在O(N)的时间复杂度内找到所有的子串删除。 无论是暴力匹配还是KMP算法,都需要实现一个删除子串的函数。这个函数可以使用常规的字符串操作实现,即将原始字符串分成要删除子串的左边和右边,然后合并成新的字符串即可。 总的来说,这道题目的难点不在于实现算法,而在于理解算法的原理以及对字符串操作的熟练度。所以需要多做一些字符串操作的习题,多练习算法实现的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值