最小覆盖子串 ---- 滑动窗口

题目链接

题目:

分析:

  • 当我们找到一组符合的子字符串时, 找下一组让left++, 那么剩余的子字符串要么还符合条件, 要么少了一种字符, right一定不用回退, 所以可以使用滑动窗口
  • 因为题目中说字符串中自包含英文字母, 所以我们可以使用hash数组
  •  定义left = 0;right = 0;
  • 进窗口
  • 进窗口后, 更新有效字符的个数, 只有当hash2中out的数量 == hash2中out的数量时, 它才是有效字符, 此时count应该加上他们的数量, 作为有效字符的数量, 因为如果tt有重复字符, 重复字符都包括时, 才算有效字符
  • 判断 有效字符count的数量和tt数组的长度是否相等, 相等才算
  • 更新结果  因为只有找到子字符串才更新, 不是所有的都要记录, 所以在判断条件里更新结果, 记录子字符串开始的下标及长度
  • 出窗口前,  更新有效字符的个数, 只有当hash2中out的数量 == hash2中out的数量时, 它才是有效字符, 此时count应该减去他们的数量, 作为有效字符的数量, 因为如果tt有重复字符, 重复字符都包括时, 才算有效字符
  • 出窗口

代码:

class Solution {
    public String minWindow(String s, String t) {
        char[] tt = t.toCharArray();
        char[] ss = s.toCharArray();
        int[] hash1 = new int[128];
        int[] hash2 = new int[128];
        int kinds = 0;
        for (char x : tt)
            if (hash1[x]++ == 0)
                kinds++;
        int left = 0;
        int right = 0;
        int count = 0;
        int minLen = Integer.MAX_VALUE;
        int begin = -1;
        while (right < ss.length) {
            char in = ss[right];
            hash2[in]++;
            if (hash1[in] == hash2[in])
                count++;
            while (count == kinds) {
                // 更新结果
                if (right - left + 1 < minLen) {
                    minLen = right - left + 1;
                    begin = left;
                }
                char out = ss[left];
                if (hash2[out] == hash1[out])
                    count--;
                hash2[out]--;
                left++;
            }
            right++;
        }
        if (begin == -1)
            return new String();
        return s.substring(begin, begin + minLen);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值