PTA基础编程题目集 7-29 删除字符串中的子串 C语言

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

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

输入格式:

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

输出格式:

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

输入样例:

Tomcat is a male ccatat
cat

输出样例:

Tom is a male 

思路分析:

题理解起来不难,但实现还是有点难度的。

1.用gets()函数接收这两个字符串数组,gets()用来接收字符串很好用噢!

2.计算s1 s2的长度

3.遍历s1数组,当s1 与s2相同时,再通过while循环来判断后续几个字符是否也相同

4.若相同,就进行逻辑上的删除,即把s1[i]的值更新:s1[i]=s1[i+L2],L2是s2的长度

5.删除完之后L1的长度要减去L2;然后遍历的 i 回溯到相同字符之前

6.循环完毕,之后输出L1(这里L1是逻辑删除之后的长度)长度的字符

代码也有注释,可以看看噢。

代码:

#include <stdio.h>
#include <stdlib.h>

int main() {
	char s1[81],s2[81];
	gets(s1);
	gets(s2);
	int L1=strlen(s1),L2=strlen(s2);
	int flag=0,i,j=0;//flag用来标志s1与s2相同的第一位,s1的位置下标 
	for(i=0;i<L1;i++){//L1的长度没经过一次删除就会改变 
		if(s1[i]==s2[j]){ 
			flag=i;
			while(s1[i]==s2[j]&&i<L1){
				i++;
				j++;
			}
			if(j>=L2){//当遍历完s2的时候就能进行删除操作 
				for(int k=flag;k<L1-L2;k++){
					s1[k]=s1[k+L2];
				}	
				i=flag-L2;//删除相同的字符串,i要回到开始相同的地方 
				j=0;
				L1=L1-L2;
			} 	
			else{
				i=flag;//同理,当遍历到ccat时,第二个c与s2中第二位不同,i要回溯 
				j=0;
			}
		}
	}
	for(i=0;i<L1;i++){
		printf("%c",s1[i]);
	} 
	return 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、付费专栏及课程。

余额充值