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

之所以要贴这个题的代码,是因为看到网上别人的代码都是套用了现成的库函数。而我刷这些题也正是因为想要从基础做起,把基础打牢,所以把我自己写的代码放在下面。注释还算清晰,就不多加解释了。

#include<stdio.h>

int main(){
	char s1[100], s2[100], ch;
	int length_1 = 0, length_2 = 0;
	int i, j, k, flag = 1;
	//分别接收两个字符串,并记录长度 
	scanf("%c", &ch);
	while(ch != '\n'){
		s1[length_1] = ch;
		length_1++;
		scanf("%c", &ch);
	}
	scanf("%c", &ch);
	while(ch != '\n'){
		s2[length_2] = ch;
		length_2++;
		scanf("%c", &ch);
	}
	//printf("%d | %d", length_1, length_2);
	//检索第一个字符串
	for(i = 0; i < length_1; i++){
		//如果某个字符等于s2[0], 且后面长度大于等于s2,则有可能包含s2的字符串
		if(s1[i] == s2[0] && length_1 - i >= length_2){
			//检查后面是否一样
			for(j = i + 1, k = 1; k < length_2; j++, k++){
				if(s1[j] != s2[k]){
					flag = 0;
					break;
				}
			}
			//如果相同, 则删除相同字符串, 重新检索 
			if(flag){
				for(j = i + length_2; j < length_1; j++)
					s1[j - length_2] = s1[j];
				length_1 -= length_2;
				i = -1;
			}	
		}		
		//重置变量
		flag = 1; 
	}
	for(i = 0; i < length_1; i++)
		printf("%c", s1[i]);
	return 0;
}

 

不同编程语言有不同的删除字符串子串的方法,以下为你介绍几种常见语言的实现方式: ### Python 在Python中,可使用`replace()`方法来删除字符串中的子串,示例代码如下: ```python original_str = "abcdefabc" sub_str = "abc" new_str = original_str.replace(sub_str, "") print(new_str) ``` 此代码利用`replace()`方法把`original_str`里的所有`sub_str`替换成空字符串,达到删除子串的目的。 ### Java 按照引用[3]的思路,Java可以通过以下代码实现从字符串删除指定子串: ```java import java.util.Scanner; public class DeleteSubstring { public static Object[] deleteSubString(String str1, String str2) { int count = 0; String result = str1; while (result.contains(str2)) { result = result.replace(str2, ""); count++; } return new Object[]{result, count}; } public static void main(String[] args) { Scanner scanner = new Scanner(System.in); StringBuilder input = new StringBuilder(); String line; while (!(line = scanner.nextLine()).equals("end")) { input.append(line); } String str1 = input.toString(); System.out.println("输入删除子串:"); String str2 = scanner.nextLine(); Object[] result = deleteSubString(str1, str2); System.out.println("删除后的字符串: " + result[0]); System.out.println("删除子串个数: " + result[1]); } } ``` 该代码从键盘循环录入字符串,直到输入`end`为止,接着调用`deleteSubString`方法从`str1`中删除所有的`str2`,并且返回删除后的字符串删除子串个数。 ### C语言(用指针实现) 依据引用[4]的代码,C语言可以通过以下方式删除字符串中的子串: ```c #include <stdio.h> #include <string.h> // BF算法求解模式匹配 int getIndex(char *str, char *sub, int pos) { int i, flag = 1; if (*sub == '\0') return -1; else { while (*(str + pos) != '\0') { if (*(str + pos) == *sub) { for (i = 1; *(sub + i) != '\0'; i++) { if (*(str + pos + i) != *(sub + i)) { flag = 0; break; } } if (flag == 1) { return pos; } } flag = 1; pos++; } return -1; } } void change(char *str, char *sub, int index) { int l1, l2, i; l1 = strlen(str); l2 = strlen(sub); for (i = index; i <= l1 - l2; i++) { *(str + i) = *(str + i + l2); } } bool delStr(char *str, char *sub) { int index = 0; index = getIndex(str, sub, index); if (index == -1) return false; change(str, sub, index); delStr(str, sub); return true; } int main() { char str[] = "abcdce"; char sub[] = "ce"; if (delStr(str, sub)) { printf("删除后的字符串: %s\n", str); } else { printf("未找到子串\n"); } return 0; } ``` 此代码运用BF算法进行模式匹配,先找到子串在主串中的位置,再把主串中匹配的子串删除。 ### C++ 根据引用[5]的代码,C++可以通过以下方式删除字符串中的子串: ```cpp #include <iostream> #include <string> // 判断是否包含 int InorNot(std::string a, std::string b) { for (int i = 0; i < a.length(); i++) { if (a[i] != b[0]) continue; else if (a[i] == b[0]) { int j; for (j = 0; j < b.length(); j++) { if (a[i + j] != b[j]) break; else continue; } if (j == b.length()) return i; } } return -1; } // 删除子串 void DelStr(std::string &m, std::string n, int d) { for (int k = d; k < m.length() - n.length(); k++) { m[k] = m[k + n.length()]; } m.resize(m.length() - n.length()); } int main() { std::string s1, s2; std::getline(std::cin, s1); std::getline(std::cin, s2); while (InorNot(s1, s2) != -1) { DelStr(s1, s2, InorNot(s1, s2)); } std::cout << s1; return 0; } ``` 该代码先判断字符串中是否包含子串,若包含则删除子串,重复此过程直到字符串中不再包含子串为止。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值