[Java][Leetcode hard] 76. 最小覆盖子串

官解: 滑动窗口 + 字符索引数组

  • 采用一个数组统计t中出现字符的频率,并用一个变量统计字符的种类
  • 移动右边界,记录在t中有出现的字符频率和种类,如果最终相等,说明符合结果,记录并比较获得最小值
  • 移动左边界,直到字符种类刚好小于原统计的字符种类,例如: s = "ADOBECODEBANC", t = "ABC" 到BEC那里开始从A移动左边界,移到D位置。
java 复制代码
class Solution {
    public String minWindow(String s, String t) {
         if(s == null || s.length() == 0 || t == null || t.length() == 0)
         return "";
         int m = s.length(), n = t.length();

         int[] need = new int[128];
         int[] window = new int[128];

         // 记录字符出现频率
         for(char c : t.toCharArray()){
            need[c]++;
         }
         // 记录字符种类
         int charKind = 0;
         for(int i=0;i<128;i++){
            if(need[i] > 0) charKind++;
         }

         int left = 0,right = 0;
         int matchKind = 0;
         int minLen = Integer.MAX_VALUE;
         int minStartIndex = 0;
         while(right < s.length()){
            char c = s.charAt(right);
            right++;

            if(need[c] > 0){
                window[c]++;
                if(window[c] == need[c]){
                    matchKind++;
                }
            }

            //  满足题目条件
            while(matchKind == charKind){
                // 记录最小覆盖子串
                if(right - left < minLen){
                    minLen = right - left;
                    minStartIndex = left;
                }

                // 缩减左边界
                char leftChar = s.charAt(left);
                left++;
                if(need[leftChar] > 0){
                    window[leftChar]--;
                    if(need[leftChar] > window[leftChar]){
                        matchKind--;
                    }
                }
            }
         }
         
         return minLen == Integer.MAX_VALUE ? "":s.substring(minStartIndex, minStartIndex + minLen);
    }
   
}```
相关推荐
小O的算法实验室2 小时前
2026年IEEE TBD,面向大规模优化的随机矩阵粒子群算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
哭泣方源炼蛊2 小时前
AtCoder Beginner Contest 456 E补题(分层图 + 有向环检测 )
c++·算法·深度优先·图论·拓扑学
MegaDataFlowers2 小时前
代码自动生成
java
平行侠2 小时前
022Miller-Rabin 概率素性检验 - 概率与数论的完美联姻
数据结构·算法
dllxhcjla2 小时前
Spring全套
java·后端·spring
wuweijianlove3 小时前
算法与数据结构协同优化的设计思想的技术7
数据结构·算法
昵称小白3 小时前
二叉树专题(下)
算法·深度优先
故事和你913 小时前
洛谷-数据结构2-1-二叉堆与树状数组1
开发语言·数据结构·c++·算法·动态规划·图论
@杰克成3 小时前
Java学习24
java·学习·idea