[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);
    }
   
}```
相关推荐
方也_arkling14 小时前
【Java-Day08】static / final / 枚举
java·开发语言
橙淮14 小时前
Spring Bean作用域与生命周期全解析
java·spring
Chengbei1114 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_11214 小时前
web-第一次课后作业
java·开发语言·idea
kkeeper~14 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
秋914 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本14 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
DIY源码阁15 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
wabs66615 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_8769641316 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉