滑动窗口算法详解:如何求解最小覆盖子串问题
创作时间:
作者:
@小白创作中心
滑动窗口算法详解:如何求解最小覆盖子串问题
引用
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);
热门推荐
光伏电站成本与收益分析:从组件价格到碳交易收益
碱性磷酸酶是什么?一文读懂其功能与临床意义
知道排量后怎样准确计算油耗?计算油耗时需要考虑哪些因素?
哈尔滨工业大学(深圳)怎么样?毕业后就业前景如何
中国银河辟谣合并传闻仍涨停 两连板后股价创历史新高
解放军步兵班,火力到底有多强?12人拿8种不同武器
申请冻结对方银行卡账户需要哪些相关证明材料
抑郁症干预:公益链接多方力量,医务社工和社区互助成为关键
灵活就业人员养老保险基数计算方法
怎样进行有效的黄金现货交易?这种交易的成本如何控制?
固态硬盘闪存类型大揭秘:MLC、TLC、QLC、SLC,你真的了解吗?
TDR首期封面文章:口腔颌面力医学推动口腔医学革新
全面解析战略评估的重要性与实施方法
甘肃新型工业化赋能高质量发展
如何开拓自己的思维方式
火车票全网“免费退”?改签费怎么收?
康复——膝|半月板修复术后康复程序
肩颈僵硬:定义、原因、症状及预防复发指南
自己打官司的法律问题
岩板背景墙如何清洁?岩板背景墙清洁要点介绍
热鲜肉和冷鲜肉的区别?
热鲜肉和冷鲜肉的区别?
厉害!西湖大学2个排名,进入世界前1000强!国内最高排名 ...
西湖大学没有5年比肩清华北大,却已经比清华北大都更有吸引力
忘记放手刹开了一段怎么办?忘记放手刹行驶后的处理方法和注意事项是什么?
如何用万用表测量电机的好坏
面部麻木最快恢复方法是什么
晚上睡觉头昏昏沉沉怎么回事
如何投资大宗商品?这些投资策略有哪些风险管理措施?
300亿防晒赛道:极致比拼,消费者反吃技术内卷红利