题目

思路
两个while循环实现滑动的感觉
代码
// leetcode76.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//
#include <iostream>
#include <string>
#include <unordered_map>
using namespace std;
string minWindow(string s, string t) {
unordered_map<char, int> need, window;
for (char c : t) need[c]++;
int left = 0, right = 0;
int valid = 0;
// 记录最小覆盖子串的起始索引及长度
int start = 0, len = INT_MAX;
while (right < s.size()) {
// c 是将移入窗口的字符
char c = s[right];
// 右移窗口
right++;
// 进行窗口内数据的一系列更新
if (need.count(c)) {
window[c]++;
if (window[c] == need[c])
valid++;//只用相等才加,window>need的时候也不加
}
// 判断左侧窗口是否要收缩
while (valid == need.size()) {
// 在这里更新最小覆盖子串
if (right - left < len) {
start = left;
len = right - left;
}
// d 是将移出窗口的字符
char d = s[left];
// 左移窗口
left++;
// 进行窗口内数据的一系列更新
if (need.count(d)) {
if (window[d] == need[d])
valid--;
window[d]--;//这个if只执行上面那句,太恶心了,把我迷惑了。
}
}
}
// 返回最小覆盖子串
return len == INT_MAX ?
"" : s.substr(start, len);
}
int main()
{
std::cout << "Hello World!\n";
}
该博客详细介绍了如何使用两个while循环实现滑动窗口算法,以找到给定字符串中匹配目标字符串的最小子串。代码中展示了如何维护窗口内的字符计数,并通过不断移动窗口边界来寻找符合条件的子串。该算法适用于字符串处理和查找问题。
868

被折叠的 条评论
为什么被折叠?



