LeetCode 76.最小覆盖子串Java

题目链接
这个是滑动窗口问题比较难的了,不太好想。
我借鉴了这个大佬的思想,用更容易理解的方式实现了一下,可能时间复杂度有点提高。
代码搭配详解使用:题解

这个是我的题解

class Solution {public String minWindow(String s, String t) {String res = "";HashMap<Character, Integer> map = new HashMap<>();int start = 0, end = 0;//把字符串t的字符出现的次数对应到哈希表里面for (int i = 0; i < t.length(); i++) {int value = map.getOrDefault(t.charAt(i), 0);map.put(t.charAt(i), value + 1);}//遍历循环体,在end走到尽头时退出for (; end < s.length(); end++) {//当匹配到t里面的字符时if (map.containsKey(s.charAt(end))) {int value = map.get(s.charAt(end));map.put(s.charAt(end), value - 1);//哨兵,判断当前是否满足覆盖子串的条件boolean flag = true;//只有当所有value都不大于0时,满足条件for (int i : map.values()) {if (i > 0) {flag = false;break;}}//满足条件,跳过无用字符,找到关键字符while (flag) {if (map.containsKey(s.charAt(start))) {int v = map.get(s.charAt(start));//点睛之笔,加一的这个操作没经验很难写出来的map.put(s.charAt(start), v + 1);for (int i : map.values()) {if (i > 0) {flag = false;break;}}//找到关键字符后,判断长度,取最小if (!flag) {if (res.length() == 0) {res = s.substring(start, end + 1);} else {res = end - start + 1 < res.length() ? s.substring(start, end + 1) : res;}}}start++;}}}return res;}
}

这个是本地IDEA上运行的代码,可以直接跑,调试。

import java.util.*;public class Main {public static String minWindow(String s, String t) {String res = "";HashMap<Character, Integer> map = new HashMap<>();int start = 0, end = 0;//把字符串t的字符出现的次数对应到哈希表里面for (int i = 0; i < t.length(); i++) {int value = map.getOrDefault(t.charAt(i), 0);map.put(t.charAt(i), value + 1);}//遍历循环体,在end走到尽头时退出for (; end < s.length(); end++) {//当匹配到t里面的字符时if (map.containsKey(s.charAt(end))) {int value = map.get(s.charAt(end));map.put(s.charAt(end), value - 1);//哨兵,判断当前是否满足覆盖子串的条件boolean flag = true;//只有当所有value都不大于0时,满足条件for (int i : map.values()) {if (i > 0) {flag = false;break;}}//满足条件,跳过无用字符,找到关键字符while (flag) {if (map.containsKey(s.charAt(start))) {int v = map.get(s.charAt(start));//点睛之笔,加一的这个操作没经验很难写出来的map.put(s.charAt(start), v + 1);for (int i : map.values()) {if (i > 0) {flag = false;break;}}//找到关键字符后,判断长度,取最小if (!flag) {if (res.length() == 0) {res = s.substring(start, end + 1);} else {res = end - start + 1 < res.length() ? s.substring(start, end + 1) : res;}}}start++;}}}return res;}public static void main(String[] args) {System.out.println(minWindow("ADOBECODEBANC", "ABC"));}
}

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

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

相关文章

【论文笔记合集】卷积神经网络之深度可分离卷积(Depthwise Separable Convolution)

本文作者&#xff1a; slience_me 我看的论文地址&#xff1a;MobileNets: Efficient Convolutional Neural Networks for Mobile Vision Applications 内容 1. 标准卷积 假设输入为DFDFM&#xff0c;输出为输入为DFDFN&#xff0c;卷积核为DKDKM&#xff0c;共有N个卷积核进…

人机对话:程序设计,学哪种语言好?

人机对话&#xff1a;程序设计&#xff0c;学哪种语言好&#xff1f; 程序设计&#xff0c;学哪种语言好&#xff1f;学习目的&#xff1a;职业发展&#xff1a;个人兴趣&#xff1a; go语言怎么样&#xff1f;优点&#xff1a;缺点&#xff1a; 要开发手机APP&#xff0c;还需…

LeetCode刷题---随机链表的复制

解题思路&#xff1a; 使用哈希表来解决该问题 因为题中要求是深拷贝 首先对原链表遍历&#xff0c;将原链表每个节点和新链表每个节点形成对应关系&#xff0c;存入到哈希表中&#xff0c;key为原链表的节点&#xff0c;value为新链表的节点。 之后重置辅助链表指向原链表头节…

墨刀原型-实现轮播图功能

在墨刀中实现轮播图效果&#xff0c;可以按照以下步骤进行操作&#xff1a; 1.添加轮播图组件&#xff1a;在墨刀的组件面板中&#xff0c;找到轮播图组件并将其拖拽到画布上。 2.上传轮播图&#xff1a;在右侧的属性面板中&#xff0c;你可以上传你的轮播图图片。点击“”按钮…

动态pv(nfs方式挂载)

1、定义 发布pvc之后可以生成pv&#xff0c;还可以在共享服务器上直接生成挂载目录 pvc直接绑定和使用pv 2、动态pv依赖两个组件 &#xff08;1&#xff09;provisioner卷插件&#xff1a;k8s本身支持的动态pv创建不包括nfs&#xff0c;需要声明和安装一个外部插件provisio…

NET Core发布 HTTP Error 500.31 - Failed to load ASP.NET Core runtime

记录一下踩过的坑&#xff1a; 首先&#xff0c;不论是500.31还是500.30 &#xff0c;首先确保安装了三个文件 1.NET Core RunTime 2.NET SDK 3.NET Hosting 其次&#xff0c;确保三个文件的版本一致&#xff0c;如下&#xff1a; 要装就统一装同一个大版本&#xff0c;不要东…

Linux第28步_编译“修改正点原子TF-A源码中的Makefile并编译生成新的TF-A 固件”

了解学习内容&#xff1a; 1)、正点原子STM32MP157开发板使用的主控型号是STM32MP157DAA1&#xff1b; 2)、“linux /atk-mp1/atk-mp1/alientek_tf-a/tf-a-stm32mp-2.2.r1”目录下的文件是正点原子STM32MP157D开发板的“TF-A源码”。 3)、“linux /atk-mp1/atk-mp1/alientek…

字符串匹配

模板&#xff1a; KMP: 细节在代码中 看不懂的可以参照&#xff1a;如何更好地理解和掌握 KMP 算法? - 阮行止的回答 - 知乎 https://www.zhihu.com/question/21923021/answer/1032665486 package StringMatch.KMP;import java.util.ArrayList; import java.util.List;publ…

k8s的配置资源管理

Secret Secret用来保存密码、token密钥以及一些敏感的k8s资源。这类数据虽然可以存放在镜像当中&#xff0c;但是放在secret当中可以更方便控制。减少暴露的风险。 Secret的作用&#xff1a;保存加密的信息 Secret的类型 docker-registry()主要用于存储docker仓库的认证信息…

后台生成随机验证码验证登录

web get请求获取图片 <div class"p2"><img id"imgId" src"/get/code"><a href"#">看不清&#xff0c;换一张</a> </div> 后台代码: /*获取动态验证码*/ ResponseBody RequestMapping(value "/…

【MATLAB源码-第113期】基于matlab的孔雀优化算法(POA)机器人栅格路径规划,输出做短路径图和适应度曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 POA&#xff08;孔雀优化算法&#xff09;是一种基于孔雀羽毛开屏行为启发的优化算法。这种算法模仿孔雀通过展开其色彩斑斓的尾羽来吸引雌性的自然行为。在算法中&#xff0c;每个孔雀代表一个潜在的解决方案&#xff0c;而…

人工智能专业必须需要考哪些证书呢?

我们来看看2024年人工智能专业的企业和个人都在紧张报考的两项AI认证证书报考&#xff1a; 为进一步贯彻落实中共中央印发《关于深化人才发展体制机制改革的意见》和国务院印发《关于“十四五”数字经济发展规划》等有关工作的部署要求&#xff0c;深入实施人才强国战略和创新驱…

程序员的职业生涯

程序员的职业生涯一般会经历以下几个阶段&#xff1a; 初级阶段&#xff1a;在这个阶段&#xff0c;程序员通常刚从大学毕业&#xff0c;或者只拥有很少的工作经验。他们开始学习如何编写代码&#xff0c;理解编程语言和开发工具&#xff0c;并熟悉软件开发流程。这个阶段的程…

Django教程第5章 | Web开发实战-数据统计图表(echarts、highchart)

专栏系列&#xff1a;Django学习教程 前言 highchart&#xff0c;国外。 echarts&#xff0c;国内。 本项目集成 hightchart和echarts图表库实现数据统计功能。 包括&#xff1a;折线图&#xff0c;柱状图&#xff0c;饼图和数据集图。 效果图 echats Highcharts 源代码…

java 判断中文英文正则表达式 排除 除了中文以外的特殊字符,排除除了英文以外的特殊字符

boolean containsChinese Pattern.matches(".*[\\u4e00-\\u9fa5].*", names);//containsChinese&#xff1a; true 包含中文就直接把其他特殊字符英文去掉if (containsChinese) {names names.replaceAll("[^\\u4E00-\\u9FA5]", "");//使用正则…

odoo17 | 编码规范大全

编码规范 本页介绍Odoo编码指南。这些旨在改善 Odoo应用程序代码的质量。事实上&#xff0c;适当的代码可以提高可读性&#xff0c;简化 维护&#xff0c;帮助调试&#xff0c;降低复杂性并提高可靠性。 这些准则应适用于每个新模块和所有新开发。 警告 在稳定版本中修改现有…

程序员如何保持竞争力

在程序员的职业生涯中&#xff0c;保持竞争力是非常重要的&#xff0c;因为技术行业不断发展和变化。以下是一些建议&#xff0c;可以帮助程序员保持竞争力&#xff1a; 持续学习新技术和编程语言&#xff1a;技术行业的发展非常快&#xff0c;新的编程语言和技术不断涌现。作为…

易点易动设备管理系统:提升企业设备能耗管理效率的不二之选

在当前环保意识日益增强的社会背景下&#xff0c;企业对设备能耗管理的重视程度不断提升。有效的能耗管理不仅可以减少企业的能源消耗和环境污染&#xff0c;还能降低生产成本和提升竞争力。为了帮助企业实现高效的设备能耗管理&#xff0c;易点易动设备管理系统应运而生。本文…

高级分布式系统-第15讲 分布式机器学习--概念与学习框架

高级分布式系统汇总&#xff1a;高级分布式系统目录汇总-CSDN博客 分布式机器学习的概念 人工智能蓬勃发展的原因&#xff1a;“大” 大数据&#xff1a;为人工智能技术的发展奠定了坚实的物质基础。 大规模机器学习模型&#xff1a;具备超强的表达能力&#xff0c;可以解决…

通过IDE和jar包运行时加载json配置文件

程序中使用了json配置文件&#xff0c;位置在$rootPath/src/main/resources/config.json, 调试时使用IDE&#xff0c;但运行时使用Jar包&#xff0c;加载config.json配置文件的代码如下&#xff1a; public ConfigParser(String configFileName) throws IOException {try{Inp…