20200229训练赛 L1 - 2 删除字符串中的子串 (20分)

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

输入格式:

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

输出格式:

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

输入样例:

Tomcat is a male ccatat
cat

输出样例:

Tom is a male

  • find(string s)返回字符串s第一次出现的开始下标,找不到返回string::npos
  • erase(a,b)从a下标开始删除,删除长度为b
#include <bits/stdc++.h>
using namespace std;
int main()
{
	string a,b;
	getline(cin,a);
	getline(cin,b);
	while(a.find(b)!=string::npos)
	{
		a.erase(a.find(b),b.length());
	}
	cout<<a;
	return 0;
}
发布了73 篇原创文章 · 获赞 26 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/l503301397/article/details/104625533