作者:小 琛
欢迎转载,请标明出处
题目:
输入两个字符串,从第一个字符串中删除第二个字符串中所有的字符
例如,输入str1为“ They are students.” 和str2为 “aeiou”, 则删除之后的第一个字符串变为“Thy r stdnts.”
题目分析:如果使用最简单多次遍历法,会导致时间复杂度极高,算法不够优化.
- 这里可以采用空间换时间的方法。定义一个数组,大小为256(char类型的字符为0-255),arr[256]全部初始化为0。
- 遍历str2,将每个字符以ASSCLL码值来对应数组下标,将该下标指向内容进行++操作
- 遍历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码值来解决问题,是常用手段,要养成惯性思维。