滑动窗口

滑动窗口算法

口诀心法

滑动窗口防滑记

解题模板

/* 滑动窗口算法框架 */
void slidingWindow(string s, string t) {
    unordered_map 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++;
            // 进行窗口内数据的一系列更新
            ...
        }
    }
}

Leetcode 上的几道经典试题

leetcode76. 最小覆盖子串 难度: 困难

leetcode567. 字符串的排列 难度:中等

leetcode438. 找到字符串中所有字母异位词 难度:中等

leetcode3. 无重复字符的最长子串 难度:中等

网络通信中的滑动窗口协议

阅读原文

labuladong的算法小抄

你可能感兴趣的:(滑动窗口)