滑动窗口算法详解:如何求解最小覆盖子串问题
创作时间:
作者:
@小白创作中心
滑动窗口算法详解:如何求解最小覆盖子串问题
引用
CSDN
1.
https://m.blog.csdn.net/xsc2004zyj/article/details/144992191
在字符串处理和算法面试中,"最小覆盖子串"是一个经典问题。本文将详细讲解如何使用滑动窗口算法解决这个问题,包括算法原理、优化思路以及完整的代码实现。
一.题目描述
- 最小覆盖子串 - 力扣(LeetCode)
二.题目解析
题目要求在字符串s中找到一个子串,该子串包含字符串t的所有字符,并返回最短的子串。如果s中不包含这样的子串,则返回一个空串。
需要注意的是:
- 如果字符串
t包含重复字符(如"aaac"),那么在s中寻找子串时必须包含所有字符,不能只出现一次。 - 子串中的字符顺序可以任意,只要包含
t中的所有字符即可。
三.算法原理
1.暴力解法
暴力解法的基本思路是枚举所有可能的子串,使用哈希表统计每个子串的字符,当子串包含t的所有字符时,记录其起始位置和长度。最后返回最短的符合条件的子串。
时间复杂度: O(N^2),因为需要反复遍历s。
空间复杂度: O(1),虽然使用了哈希表,但存储的都是字母,空间是常数级的。
2.滑动窗口
可以对暴力枚举进行优化,采用滑动窗口算法:
- 进窗口: right位置的元素放入哈希表中
- 判断: 如果子串满足要求,就更新结果,然后让left位置的元素出窗口
- 时间复杂度: O(N+t),left和right最多各遍历一次
s,判断时需要遍历哈希表 - 空间复杂度: O(1),字符集只有52个字母
3.滑动窗口优化
通过引入count计数器来优化判断逻辑:
- 入窗口时: 如果该元素在两个哈希表的个数相等,说明这个字符已经满足
t中该字符的出现要求,count++ - 出窗口前: 如果两个哈希表中该字符个数相等,说明该字符是有效字符,出去后
count-- - 判断逻辑:
count统计有效字符的种类,与t的哈希表大小进行比较
四.代码实现
在进行滑动窗口之前,需要记录t的哈希表大小,因为在滑动窗口过程中,哈希表会插入元素导致大小变化。同时,需要记录子串的起始位置和长度。
string ret;
int n = s.size();
int m = t.size();
if (n < m)
return ret;
unordered_map<char, int> mp_t; // 统计t字符串中字符的出现次数
unordered_map<char, int> mp_s; // 统计窗口中字符的出现次数
for (auto e : t) mp_t[e]++;
int judge = mp_t.size();
int len = 0, beg = 0;
for (int l = 0, r = 0, count = 0; r < n; ++r) // count标记有效字符的种类
{
// 进窗口 + 维护count
mp_s[s[r]]++;
if (mp_s[s[r]] == mp_t[s[r]]) count++;
// 判断
while (count == judge)
{
// 更新结果
int prev = len;
len = len == 0 ? (r - l + 1) : min(len, r - l + 1);
if (len != prev) beg = l;
// 出窗口
if (mp_s[s[l]] == mp_t[s[l]]) count--;
mp_s[s[l++]]--;
}
}
return s.substr(beg, len);
热门推荐
分子的性质
深圳“最后一个棚改项目”规划公布:住宅约11万㎡,将建4栋48F高层
2025春节消费大调研:7个你从没注意的真相
acrobat dc 怎么批量删除PDF上每一页上的特定文字
舒适与优雅并存:低饱和日系穿搭指南
Excel中插入和管理多张图片的完整指南
如何与货代公司签订物流合同?(跨境电商必备技能)
如何在车辆保险领域做出合适的选择?这些选择有哪些注意事项?
厨房操作台尺寸标准尺寸
给孩子上户口名字最新规定
《马云传》:从平凡到非凡,揭秘阿里巴巴帝国缔造者的传奇人生与商业智慧
裙带菜的功效和作用 裙带菜营养价值有哪些
专家解读:裙带菜的营养价值与食用注意事项
X射线衍射测试粉末样品时有什么要求
掌握XRD衍射仪样品制样精髓,提升检测效率与质量
可转债转成股票数量计算方法及转换比例分析
大学学分有哪些
家族信托在家族财富管理中有何作用,家族信托有哪些优势?
一些有趣的无理数
如何查询诉讼证据的真实性及其法律效力
如何判断网上律师追款的真实性
16+8 跌下神坛,增加 91% 心血管死亡风险?轻断食该继续吗?
身体不适并感到呼吸困难和头晕应该如何处理
金宇澄小说《繁花》人物解读:姝华,一个文艺女青年的“花凋”
生产看板是什么?生产看板的作用、类型及应用场景全解析
离婚判决过后多久可以再次起诉
法院调解后是否可以重新起诉
方大同的华语R&B革新
刘邦及其后代建立的6个王朝和41位皇帝打下的500年江山
房屋纠纷不再愁,这些投诉渠道帮你搞定