Leetcode JAVA刷刷站(76)最小覆盖子串

news2024/9/20 9:46:17

 一、题目概述

二、思路方向 

       为了解决这个问题,我们可以使用滑动窗口的方法。滑动窗口是数组/字符串问题中常用的一个技巧,特别是用于寻找子数组或子字符串的问题。

       这里的关键是,我们需要知道字符串t中每个字符的出现次数,并在遍历字符串s时维护一个窗口,这个窗口内的字符种类和数量需要能够“覆盖”字符串t中的所有字符。

以下是用Java实现的详细步骤:

  1. 初始化:使用HashMap来记录字符串t中每个字符的出现次数(need),并同时统计t中不同字符的总数(required)。

  2. 双指针滑动窗口:使用两个指针leftright来维护一个滑动窗口,其中right指针用于扩展窗口,left指针用于缩小窗口。

  3. 窗口内字符的计数:使用一个HashMap(例如window)来记录当前窗口内每个字符的出现次数。

  4. 移动right指针:扩展窗口,每次移动right指针时,增加window[s[right]]的计数。

  5. 检查窗口:如果窗口内的字符种类和数量能够覆盖t中的字符,则尝试缩小窗口(移动left指针),直到窗口不再满足覆盖条件或达到最小。

  6. 更新结果:在每次满足覆盖条件时,比较并更新最小子串的起始位置和长度。

  7. 返回结果:如果找到了满足条件的子串,则返回该子串;否则,返回空字符串。

三、代码实现  

import java.util.HashMap;  
import java.util.Map;  
  
public class Solution {  
    public String minWindow(String s, String t) {  
        Map<Character, Integer> need = new HashMap<>();  
        Map<Character, Integer> window = new HashMap<>();  
  
        // 统计t中每个字符的出现次数  
        for (char c : t.toCharArray()) {  
            need.put(c, need.getOrDefault(c, 0) + 1);  
        }  
  
        int left = 0, right = 0;  
        int required = need.size(); // t中不同字符的总数  
        int[] result = {-1, 0, 0}; // {起始索引, 子串长度, 0(占位符)}  
  
        while (right < s.length()) {  
            // c 是将移入窗口的字符  
            char c = s.charAt(right);  
            // 扩大窗口  
            if (need.containsKey(c)) {  
                window.put(c, window.getOrDefault(c, 0) + 1);  
                if (window.get(c).equals(need.get(c))) {  
                    required--;  
                }  
            }  
            right++;  
  
            // 尝试缩小窗口  
            while (required == 0) {  
                // 在这里更新最小覆盖子串  
                if (result[1] == 0 || right - left < result[1]) {  
                    result[0] = left;  
                    result[1] = right - left;  
                }  
                // d 是将移出窗口的字符  
                char d = s.charAt(left);  
                // 缩小窗口  
                if (need.containsKey(d)) {  
                    if (window.get(d).equals(need.get(d))) {  
                        required++;  
                    }  
                    window.put(d, window.get(d) - 1);  
                }  
                left++;  
            }  
        }  
  
        // 根据result数组构建最小覆盖子串  
        return result[1] == 0 ? "" : s.substring(result[0], result[0] + result[1]);  
    }  
  
    public static void main(String[] args) {  
        Solution solution = new Solution();  
        String s = "ADOBECODEBANC";  
        String t = "ABC";  
        System.out.println(solution.minWindow(s, t)); // "BANC"  
    }  
}

执行结果: 

四、小结

       这段代码首先通过两个HashMap来记录需要匹配的字符和当前窗口中的字符,然后通过双指针来维护一个滑动窗口,不断尝试缩小窗口直到不满足条件,并在过程中记录最小覆盖子串。

 结语  

好的事情总是发生在最后

当你觉得不能接受的时候

它却来到了身边

!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2065387.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Python】函数高阶【上】

本篇文章将讲解函数高阶部分&#xff1a; &#xff08;1&#xff09;函数的嵌套 &#xff08;2&#xff09;闭包 &#xff08;3&#xff09;装饰器 1、函数的嵌套 Python是以函数为作用域&#xff0c;在作用域中定义的相关数据只能被当前作用域或子作用域使用。 &#xf…

(QT-UI)十四、在时间轴上绘制一段段时间片

本系列预计实现 ①刻度上方文字显示&#xff0c; ②时间轴拖动效果&#xff0c; ③时间轴刻度缩放&#xff0c; ④时间轴和其他控件联动显示&#xff0c; ⑤鼠标放置到时间轴&#xff0c;显示具体时间。 ⑥通过定时器&#xff0c;实时更新时间轴 ⑦时间轴上绘制时间片 完…

PostgreSQL11 | 事务处理与并发控制

PostgreSQL11 | 事务处理与并发控制 本文章代码已在pgsql11.22版本上运行且通过&#xff0c;展示页由pgAdmin8.4版本提供&#xff0c;本文章第一次采用md文档&#xff0c;效果比csdn官方富文本编辑器好用&#xff0c;以后的文章都将采用md文档 事务管理简介 事物是pgsql中的…

自己动手写CPU_step2_构建SOPC

ROM实现指令寄存器 上一篇中实现的五级流水线需要一个输入&#xff0c;这个输入是指令数据&#xff0c;而指令数据是通过取指阶段的PC控制的&#xff0c;PC会一直循环的取指令。 指令寄存器实现&#xff1a; //指令寄存器 module inst_rom(input clk,inp…

【C++ Primer Plus习题】2.1

问题: 解答: #include <iostream> using namespace std;int main() {cout << "在下国林!" << endl;cout << "家住天府之国!" << endl;return 0; }运行结果: 考查点: 预处理头文件命名空间main函数c的标准输出和换行字符…

机器学习/数据分析--通俗语言带你入门K-邻近算法(结合案例)

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 前言 机器学习是深度学习和数据分析的基础&#xff0c;接下来将更新常见的机器学习算法注意&#xff1a;在打数学建模比赛中&#xff0c;机器学习用的也很多&a…

初识Linux · yum和vim

目录 前言&#xff1a; 1 yum 1.1 yum是什么&#xff1f; 1.2 Centos的生态和yum的本地配置 1.3 yum的相关操作 2 vim 前言&#xff1a; 我们学习Linux的时候&#xff0c;是有编程语言的基础的&#xff0c;那么呢&#xff0c;我们学习Linux的时候最迫切的就是希望能打印…

Flat Ads:全球金融应用现状与发展趋势深度解析

随着全球数字化进程的加速,金融科技(FinTech)应用正逐渐成为现代生活不可或缺的一部分。从移动银行到数字支付,再到智能理财工具,金融应用正在重新定义传统金融服务的边界,并推动行业的深刻变革。 本篇文章 Flat Ads 将从全球视角出发,深入剖析当前金融应用市场的现状,探讨未来…

开关电源测试系统方案:系统结构功能、特点、测试项目

为了应对开关电源测试中的复杂挑战&#xff0c;我们推出了NSAT-8000系列开关电源ate测试系统&#xff0c;它以其全面的功能和灵活性&#xff0c;适应了电源产品测试场景&#xff0c;解决了测试难题。 开关电源测试系统 NSAT-8000系列之开关电源测试系统适用于AC/DC和DC/DC开关电…

苹果macbook电脑怎么玩《黑神话:悟空》游戏教程来了

火爆全网《黑神话&#xff1a;悟空》是一款基于中国神话故事《西游记》改编的动作角色扮演游戏&#xff0c;它在PC平台上的系统要求已经公布&#xff0c;但目前官方尚未发布Mac版本。不过&#xff0c;Mac用户可以通过使用系统兼容工具如CrossOver来尝试在Mac上运行这款游戏。Cr…

《黑神话:悟空》游戏攻略:第一回合打法教程!

《黑神话&#xff1a;悟空》是一款以西游记为背景的动作角色扮演游戏&#xff0c;玩家在游戏中将面对各式各样的强大敌人和BOSS。在游戏的第一回合中&#xff0c;你将遇到牯护院、灵虚子、幽魂等多个BOSS。以下是详细的BOSS打法攻略&#xff0c;帮助你在战斗中游刃有余。你可以…

Ubuntu22安装MySQL8,并关闭大小写

最近因为设置MySQL不区分大小写踩了很多坑&#xff0c;把解决过程记录下来。 首先我这个是阿里云全新服务器&#xff0c;操作系统&#xff1a;Ubuntu 22.04 64位 连接到服务器后&#xff1a; 1 安装MySQL 1.1 更新软件包 以下命令皆已单独放至代码块内&#xff0c;直接复制…

服务器配置miniconda环境

目录 1. 查看服务器的操作系统2. 查看服务器的cuda版本3. 配置开发环境3.1 安装miniconda3环境3.2 创建虚拟环境3.3 在虚拟环境中安装pytorch3.4 在虚拟环境中安装库 1. 查看服务器的操作系统 执行代码&#xff1a; uname -a发现是Ubuntu 22.04 2. 查看服务器的cuda版本 执…

鸿蒙OS应用开发例题

单选题 第24/60题 自动跳下一题0 在编译构建HAP时&#xff0c;会从HAP模块及依赖的模块中收集资源文件&#xff0c;如果不同模块下的资源文件出现重名冲突 时&#xff0c;会按照优先级进行覆盖&#xff0c;现在有一个HAP依赖了两个HAR,依赖配置如下所示: // oh-package. j…

柔性织物处理 | 山大宋锐老师 | 最新演讲

笔者是清华在读研究生&#xff0c;主要关注人形机器人、具身智能。将持续分享行业前沿动态、学者观点整理、论文阅读笔记、知识学习路线等。欢迎交流 最近听了宋老师的演讲&#xff0c;以下是学习整理。部分图截自直播&#xff0c;若模糊望见谅 演讲信息&#xff1a; 【会议】…

郁李:花语与植物特征的魅力探寻

一、花语的奥秘 郁李的花语丰富多样&#xff0c;其中 “忠实” 代表着坚定不移的忠诚和信任&#xff0c;寓意着一份真挚而深厚的情感&#xff0c;无论外界如何变化&#xff0c;都能保持初心不变。“困难” 这一花语似乎不太讨喜&#xff0c;它可能象征着人生道路上难免会遭遇的…

iOS 通知

iOS 通知分为本地推送和远程推送两类 一. 本地推送使用流程 1. 注册通知 //请求通知权限 UNUserNotificationCenter *center [UNUserNotificationCenter currentNotificationCenter];[center requestAuthorizationWithOptions:(UNAuthorizationOptionBadge | UNAuthorizati…

Java学习_18_Stream流

文章目录 前言一、不可变集合二、Stream流思想第一步&#xff1a;得到Stream流第二步&#xff1a;Stream流的中间方法Stream流的终结方法 总结 前言 博客仅记录个人学习进度和一些查缺补漏。 学习内容&#xff1a;BV17F411T7Ao 一、不可变集合 不可变集合就是长度和内容都不可…

HTML+CSS浮动和清除浮动的效果及其应用场景举例

一、清除浮动的效果 解释 .container&#xff1a;用于展示浮动和清除浮动效果的容器&#xff0c;具有边框和背景色以便于区分。 .float-box&#xff1a;浮动元素&#xff0c;用不同的背景色标识。 .clearfix&#xff1a;使用伪元素清除浮动的类&#xff0c;应用于第二个容器。 …

【chips】个人笔记系列-SystemVerilog

Title&#xff1a;System Verilog 学习 背景与发展 什么是SV 啥是SystemVerilog&#xff1f; 就是用来专门写验证和测试的 Verilog 升级版——在verilog的基础上加了些C的思想、语法、模块。 为啥要搞出一个SystemVerilog&#xff1f; 设计IC (integrated circuit)时用的是 …