【Hot100】LeetCode—76. 最小覆盖子串

题目


1- 思路

利用两个哈希表解决分为 :① 初始化哈希表②遍历 s,处理当前元素,判断当前字符是否有效③收缩窗口④更新最小覆盖子串


2- 实现

⭐76. 最小覆盖子串------题解思路

java 复制代码
class Solution {
    public String minWindow(String s, String t) {

        // 定义两个 HashMap
        HashMap<Character,Integer> hs = new HashMap<>();
        HashMap<Character,Integer> ht = new HashMap<>();
        // 定义 
        int cnt = 0;
        String res = "";

        // 初始化 ht
        for(int i = 0 ; i < t.length();i++){
            char c = t.charAt(i);
            ht.put(c,ht.containsKey(c) ? ht.get(c)+1:1);

        }

        // 遍历 s
        for(int i = 0, j = 0 ; i < s.length();i++){
            char c = s.charAt(i);
            hs.put(c, hs.containsKey(c) ? hs.get(c)+1 : 1);

            // 判断 i 合法
            if(ht.containsKey(c) && hs.get(c) <= ht.get(c)) cnt++;

            // 缩小区间
            while (j <= i && (!ht.containsKey(s.charAt(j)) || hs.get(s.charAt(j)) > ht.get(s.charAt(j)))) 
            {
                hs.put(s.charAt(j), hs.get(s.charAt(j ++)) - 1);
            }

            // 3 收集结果
            // 首先是必须等于 cnt && (hs.length()> (i-j+1) || res.length()<1)
            if(cnt==t.length() && ( res.length() > (i-j+1) || res.length()<1)){
                res = s.substring(j,i+1);
            }

        }
        return res;
    }
}

3- ACM 实现

java 复制代码
public class minWindow {

    public static String minWindow(String s,String t){
        // 1.数据结构
        HashMap<Character,Integer> ht = new HashMap<>();
        HashMap<Character,Integer> window = new HashMap<>();
        int cnt = 0;
        String res = "";

        // 2.遍历 t 初始化 ht
        for(int i = 0 ; i < t.length();i++){
            char c = t.charAt(i);
            ht.put(c,ht.containsKey(c)? ht.get(c)+1:1);
        }

        // 3.遍历 s
        for(int i = 0,j=0 ; i < s.length();i++){
            char cc = s.charAt(i);
            window.put(cc,window.containsKey(cc)? window.get(cc)+1:1);

            // 判 cc 断有效性
            // 在 ht 中
            if(ht.containsKey(cc) && window.get(cc) <=
                    ht.get(cc)) cnt++;

            // 窗口收缩
            while(j<=i && (!ht.containsKey(s.charAt(j)) || window.get(s.charAt(j)) > ht.get(s.charAt(j)))){
                window.put(s.charAt(j),window.get(s.charAt(j++))-1);
            }

            // 更行 res
            if(cnt == t.length() && (res.length()>(i-j+1) || res.length()<1)){
                res = s.substring(j,i+1);
            }
        }
        return res;
    }


    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("输入字符串1");
        String s = sc.nextLine();

        System.out.println("输入字符串2");
        String t = sc.nextLine();
        String res = minWindow(s,t);
        System.out.println("结果是"+ res);
    }
}

相关推荐
骑着王八撵玉兔5 分钟前
【非关系型数据库Redis 】 入门
java·数据库·spring boot·redis·后端·缓存·nosql
小七蒙恩30 分钟前
java 上传txt json等类型文件解析后返回给前端
java·前端·json
郭老师的小迷弟雅思莫了1 小时前
【JAVA高级篇教学】第六篇:Springboot实现WebSocket
java·spring boot·websocket
KeyPan1 小时前
【视觉SLAM:八、后端Ⅰ】
人工智能·数码相机·算法·机器学习·计算机视觉
Jackilina_Stone2 小时前
【论文阅读笔记】SCI算法与代码 | 低照度图像增强 | 2022.4.21
论文阅读·人工智能·笔记·python·算法·计算机视觉
神仙别闹2 小时前
基于Java+MySQL实现的(GUI)酒店管理系统(软件工程设计)
java·mysql·软件工程
正在绘制中2 小时前
Java重要面试名词整理(十五):Dubbo
java·面试·dubbo
小羊小羊,遇事不难2 小时前
Error: near “112136084“: syntax
java·服务器·前端
逐星ing3 小时前
【AIGC】使用Java实现Azure语音服务批量转录功能:完整指南
java·人工智能·aigc·语音识别·azure
全栈师3 小时前
WinForm事件遇到异步方法的处理方式
java·开发语言·c#