当前位置: 首页 > news >正文

leetcode76.最小覆盖子串

思路源于

【小白都能听懂的算法课】【力扣】【LeetCode 76】最小覆盖子串|滑动窗口|字符串

 初始化先创建t的哈希表记录t中的字符以及它出现的次数,t的have记录t中有几种字符

s的哈希表记录窗口中涵盖t的字符以及它出现的次数,初始化时出现次数全部为0,s的have记录s中有几种字符已经覆盖了t中的字符

先滑动右指针扩大窗口,只要遇到t中有的字符,就让s哈希表对应字符出现次数+1,直到s能覆盖t(sHave==tHave时),这时就要记录下这个窗口(也就是可能是最终结果的子串)的起始位置和终止位置,并且不断将左指针移动缩小窗口,如果碰到t中存在的字符那么就要让s哈希表对应字符出现次数-1,直到s刚好不能覆盖t(sHave==tHave-1时)。不断重复这个过程直到滑动窗口边界越出就结束了

class Solution {
    public String minWindow(String s, String t) {
        int sStart = 0, sEnd = s.length();
        int sHave = 0, tHave = 0;
        Map<Character, Integer> sMap = new HashMap<>();
        Map<Character, Integer> tMap = new HashMap<>();
        for (int i = 0; i < t.length(); i++) {
            char charAt = t.charAt(i);
            if (!tMap.containsKey(charAt)) {
                tHave++;
                tMap.put(charAt, 1);
                sMap.put(charAt, 0);
            } else {
                tMap.put(charAt, tMap.get(charAt) + 1);
            }
        }
        for (int right = 0, left = 0; right < s.length(); right++) {
            if (tMap.containsKey(s.charAt(right))) {
                char charAtRight = s.charAt(right);
                sMap.put(charAtRight, sMap.get(charAtRight) + 1);
                //若是刚好新增某个字符达到和t中字符数量一致的情况,则认为s中这个字符刚好覆盖
                if (sMap.get(charAtRight).equals(tMap.get(charAtRight))) {
                    sHave++;
                }
                while (sHave == tHave) {
                    //更新结果子串的开始索引和结束索引
                    if (right - left < sEnd - sStart) {
                        sStart = left;
                        sEnd = right;
                    }
                    char charAtLeft = s.charAt(left);
                    if (tMap.containsKey(charAtLeft)) {
                        sMap.put(charAtLeft, sMap.get(charAtLeft) - 1);
                        //若是刚好删除某个字符导致t中这个字符无法覆盖s中的这个字符
                        if (sMap.get(charAtLeft).equals(tMap.get(charAtLeft) - 1)) {
                            sHave--;
                        }
                    }
                    left++;
                }
            }
        }
        return sEnd == s.length() ? "" : s.substring(sStart, sEnd + 1);
    }
}

 

http://www.dtcms.com/a/109381.html

相关文章:

  • podman和与docker的比较 及podman使用
  • Linux红帽:RHCSA认证知识讲解(九)标准输入输出、重定向、过滤器与管道
  • PyTorch的dataloader制作自定义数据集
  • Golang改进后的任务调度系统分析
  • MySQL的进阶语法12(MySQL管理)
  • [250403] HuggingFace 新增检查模型与电脑兼容性的功能 | Firefox 发布137.0 支持标签组
  • 数据库系统-数据库模式
  • UART双向通信实现(序列机)
  • (三十)导入系统内置库 math库
  • 基于大模型预测升主动脉瘤的多维度诊疗研究报告
  • 抖音短视频安卓版流畅度测评 - 真实
  • 关于pycharm远程连接服务器如何debug
  • ngx_log_init
  • RTOS基础 -- NXP M4小核的RPMsg-lite与端点机制回顾
  • Qt基础:主界面窗口类QMainWindow
  • 前端切片上传、上传进度、断点续传、秒传
  • maven项目添加第三方JAR包
  • 《Java编程思想》读书笔记:第九章 接口
  • TI-BQ34Z100 STM32CubeIDE STM32L151 调试过程,含详细步骤文档、代码工程、测试记录、BQ34Z100手册等相关资料
  • 数据框的添加
  • P2758 编辑距离
  • 08_paho.mqtt.cpp库使用示例
  • Python学习笔记(8)关于列表内置函数和多维列表
  • Java 常用数据结构详解
  • Java8 到 Java21 系列之 Stream API:数据处理的新方式(Java 8)
  • Node.js 安装与配置全攻略:从入门到高效开发
  • 做题记录:和为K的子数组
  • 二极管正负极区分
  • Mermaid 语法教程
  • kali中vmtools失效用不了解决方法