滑动窗口算法详解:如何求解最小覆盖子串问题
创作时间:
作者:
@小白创作中心
滑动窗口算法详解:如何求解最小覆盖子串问题
引用
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);
热门推荐
学3d动画制作需要学什么?从入门到精通的学习内容详解
神秘巨星:中子星的诞生与威力揭秘
配电网故障的“GPS”:行波定位技术应用
如何查项目的红线范围
如何购买旅游保险?这种保险购买有哪些要点?
在石头缝里“掘金”?看石漠化治理的广西探索!
仅剩3名员工?曾经爆火的《旅行青蛙》国服宣布渠道服停运
喝了水一会就要小便一次正常吗
函数奇偶性的判断口诀及性质详解
《对马岛之魂》PC版将实现跨平台联机与奖杯同步
没有产权只有使用权的车位能买吗
懷孕聽胎教音樂有用嗎?每天「這時間」聽最有效!
藤藤蛇的性格与特性:一种云南特有蛇类的生态探秘
塞拉门控制原理- BUS ELECTRICAL INSTA
异食癖的病因和防治
沈阳十大景点推荐:从故宫到棋盘山,领略沈阳历史文化与现代风情
滚筒洗衣机的浸泡清洗法(用水温和洗剂)
邻里纠纷事件引发关注,媒体深入调查揭示矛盾根源
藥不能停 特別是這10種
长期服用苯妥英钠的副作用和危害
金钱草的养护要点:从光照到病虫害防治的全方位指南
身上很多脂肪瘤怎么办
德怀特·戴维·艾森豪威尔——从战场到白宫的传奇人生
产业链供应链:坚持自主可控 确保安全稳定
不过户的二手车能买吗?一文详解二手车交易关键要点
选题策划:从理论到实践的全方位指南
买房能用小孩的名字买吗
喝苏打水能降尿酸,治疗痛风?真正要喝的是这种饮品
被申请执行人有什么权利?
如何找到最适合你的听力解决方案