算法框架:
/* 滑动窗口算法框架 */
void slidingWindow(string s, string t) {
unordered_map<char, int> need, window;
for (char c : t) need[c]++;
int left = 0, right = 0;
int valid = 0;
while (right < s.size()) {
// c 是将移入窗口的字符
char c = s[right];
// 右移窗口
right++;
// 进行窗口内数据的一系列更新
...
/*** debug 输出的位置 ***/
printf("window: [%d, %d)\n", left, right);
/********************/
// 判断左侧窗口是否要收缩
while (window needs shrink) {
// d 是将移出窗口的字符
char d = s[left];
// 左移窗口
left++;
// 进行窗口内数据的一系列更新
...
}
}
}
C++实现:
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++;
}
// 判断左侧窗口是否要收缩
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]--;
}
}
}
// 返回最小覆盖子串
return len == INT_MAX ?
"" : s.substr(start, len);
}
Java实现:
public static String minWindow(String s, String t) {
HashMap<Character, Integer> need = new HashMap<>();
HashMap<Character, Integer> window = new HashMap<>();
for (char c : t.toCharArray()) {
need.put(c, need.getOrDefault(c,0)+1);
}
int left = 0;
int right = 0;
int valid = 0;
//记录最小覆盖子串的起始索引和长度
int start = 0;
int len = Integer.MAX_VALUE;
while (right<s.length()){
//c是将移入窗口的字符
char c = s.charAt(right);
//右移窗口
right++;
//进行窗口内数据的一系列更新
if (need.containsKey(c)){
window.put(c,window.getOrDefault(c,0)+1);
if (window.get(c)==need.get(c)){
valid++;
}
}
//判断左侧窗口是否需要收缩
while (valid==need.size()){
//在这里立更新最小覆盖子串
if (right-left<len){
start=left;
len=right-left;
}
//d是将要移出窗口的字符
char d = s.charAt(left);
//左侧窗口收缩
left++;
//进行窗口内数据的一系列更新
if (need.containsKey(d)){
if (window.get(d)==need.get(d)){
valid--;
}
window.put(d,window.get(d)-1);
}
}
}
return len==Integer.MAX_VALUE ? "":s.substring(start,start+len);
}