Bootstrap

输入两个字符串,从第一个字符串中删除第二个字符串中所有的字符

作者:小 琛
欢迎转载,请标明出处

题目:
输入两个字符串,从第一个字符串中删除第二个字符串中所有的字符
例如,输入str1为“ They are students.” 和str2为 “aeiou”, 则删除之后的第一个字符串变为“Thy r stdnts.”

题目分析:如果使用最简单多次遍历法,会导致时间复杂度极高,算法不够优化.

  1. 这里可以采用空间换时间的方法。定义一个数组,大小为256(char类型的字符为0-255),arr[256]全部初始化为0
  2. 遍历str2,将每个字符以ASSCLL码值来对应数组下标,将该下标指向内容进行++操作
  3. 遍历srr1,再次利用每个字符的ASSCLL码值对应数组下标,若该下标所指向的内容不为0,则表示str2中有该字符,删除该字符即可。
#include <iostream>
#include <string.h>
//1、输入两个字符串,从第一个字符串中删除第二个字符串中所有的字符
//例如,输入“ They are students.” 和 “aeiou”, 则删除之后的第一个字符串变为“Thy r stdnts.”
void delete_str(std::string& str1,  std::string& str2)
{
	if (str1.empty() || str2.empty())
		return;
	size_t arr[256] = { 0 };
	for (auto ch : str2)
	{
		arr[ch]++;
	}
	for (size_t i = 0; i < str1.size();i++)
	{
		if (arr[str2[i]] != 0)
			str1.erase(i, 1);
	}
}
void text1()
{
	std::string str1;
	std::string str2;
	std::getline(std::cin, str1);
	std::getline(std::cin, str2);
	delete_str(str1, str2);
	for (auto ch : str1)
	{
		std::cout << ch;
	}
}

反思总结:要实现一道题目解析一类题目,在字符串类型的题目中,定义数组并利用ASSCLL码值来解决问题,是常用手段,要养成惯性思维。

;