0
点赞
收藏
分享

微信扫一扫

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

北邮郭大宝 2022-03-11 阅读 61
c++pta

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

输入格式:

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

输出格式:

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

输入样例:

Tomcat is a male ccatat
cat

输出样例:

Tom is a male 

题目分析:

1.行输入getline

2.不是简单的暴力循环,而是不断地删除子串

3.要熟悉find,erase(string库)的用法

代码如下:

#include<iostream>
#include<string>
using namespace std;
int main()
{
	string input;
	string want_delete;
	getline(cin, input);//行输入
	getline(cin, want_delete);//行输入
	int x = input.find(want_delete);
	while (x!=string::npos) {//若find返回npos(-1),则循环结束
		input.erase(x, want_delete.length());//删除子字符串
		x = input.find(want_delete);//再次寻找(因为找到一个只会标记第一个位置)
	}
	cout << input;
	return 0;
}

 

举报

相关推荐

0 条评论