作者:小 琛
欢迎转载,请标明出处
题目:
输入两个字符串,从第一个字符串中删除第二个字符串中所有的字符
例如,输入str1为“ They are students.” 和str2为 “aeiou”, 则删除之后的第一个字符串变为“Thy r stdnts.”
题目分析:如果使用最简单多次遍历法,会导致时间复杂度极高,算法不够优化.
#include
#include
//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码值来解决问题,是常用手段,要养成惯性思维。