leetcode——滑动窗口题目汇总

本章总结一下滑动窗口的解题思路:

  • 在字符串中使用双指针 left right 围成的一个左闭右开的区域作为一个窗口。
  • 不断将 right 向右滑动,直到窗口中的字符串符合条件。
  • 此时将 left 向右滑动,直到窗口中的字符串不符合条件,期间需不断的更新结果。
  • 最后重复前两步,直到 right 指针达到尽头。

需要的变量:

  • 需要维护两个map数组,needwindow,分别记录所需要的字符及个数,和滑动窗口中的字符及个数。
  • 左右指针left 和 right ,分别初始化为0。
  • valid 用于记录窗口中符合条件的字符数,初始化为0。

leetcode76、最小覆盖子串

        java代码如下: 

class Solution {public String minWindow(String s, String t) {HashMap<Character,Integer> need = new HashMap<>(); //所需要的字符及个数HashMap<Character,Integer> window = new HashMap<>(); //滑动窗口内的符合need的字符及个数//滑动窗口的左右指针int left = 0, right = 0;int valid = 0;for(char c : t.toCharArray()){need.put(c,need.getOrDefault(c,0)+1);}//最小覆盖子串的起始索引及长度int start = 0, len = Integer.MAX_VALUE;while(right < s.length()){char c = s.charAt(right);//右移窗口right++;//更新窗口内数据if(need.containsKey(c)){window.put(c,window.getOrDefault(c,0)+1);if(window.get(c).equals(need.get(c))){valid++;}}//判断窗口是否需要收缩while(valid == need.size()){//更新最小覆盖子串if(right - left < len){start = left;len = right - left;}char d = s.charAt(left);//左移窗口left++;//更新窗口数据if(need.containsKey(d)){if(window.get(d).equals(need.get(d))){valid--;}window.put(d,window.get(d)-1);}}}if(len == Integer.MAX_VALUE) return "";return s.substring(start,start+len);}
}

leetcode438、找到字符串中所有字母异位词

        除了判断窗口是否要收缩的代码不一样,其他基本都一样,代码如下:

class Solution {public List<Integer> findAnagrams(String s, String p) {Map<Character,Integer> need = new HashMap<>();Map<Character,Integer> window = new HashMap<>();int left = 0, right = 0;int valid = 0;List<Integer> ans = new ArrayList<>();for(Character c : p.toCharArray()){need.put(c,need.getOrDefault(c,0)+1);}while(right < s.length()){char c = s.charAt(right);right++;if(need.containsKey(c)){window.put(c,window.getOrDefault(c,0)+1);if(window.get(c).equals(need.get(c))){valid++;}}while(right - left >= p.length()){if(valid == need.size()){ans.add(left);}char d = s.charAt(left);left++;if(need.containsKey(d)){if(window.get(d).equals(need.get(d))){valid--;}window.put(d,window.get(d)-1);}}}return ans;}
}

leetcode3、无重复字符的最长子串

 

        本题不需要 need,并且判断是否收缩的代码逻辑为:当前窗口是否存在重复字符。 java代码如下:

class Solution {public int lengthOfLongestSubstring(String s) {Map<Character,Integer> window = new HashMap<>();int left = 0, right = 0;int ans = 0;while(right < s.length()){char c = s.charAt(right);right++;window.put(c,window.getOrDefault(c,0)+1);//当出现重复字符,窗口收缩while(window.get(c) > 1){char d = s.charAt(left);left++;window.put(d,window.get(d)-1);}ans = Math.max(ans, right-left);}return ans;}
}

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

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

相关文章

Django中的SQL注入攻击防御策略

Django中的SQL注入攻击防御策略 SQL注入是一种常见的网络安全威胁&#xff0c;可以导致数据库被非法访问和数据泄露。本文将介绍在Django框架中防止SQL注入攻击的关键方法&#xff0c;包括使用参数化查询、使用ORM、进行输入验证和使用安全的编码实践。 SQL注入是一种利用应用程…

SpringBoot:多环境配置

多环境配置demo代码&#xff1a;点击查看LearnSpringBoot02 点击查看更多的SpringBoot教程 方式一、多个properties文件配置 注意&#xff1a;创建properties文件,命名规则&#xff1a;application-&#xff08;环境名称&#xff09; 示例&#xff1a;application-dev.proper…

循环神经网络(RNN)简介与应用

循环神经网络&#xff08;RNN&#xff09;简介与应用 一、RNN基本概念二、RNN原理解析2.1 RNN网络结构RNN网络主要组件输入层(Input)&#xff0c;隐藏层(Hidden State)&#xff0c;输出层(Output)循环单元(Recurrent Unit)权重参数(Weights)和偏置项(Bias) RNN的数据流向时间步…

算法刷题day10

目录 引言一、最长上升子序列二、地宫取宝三、波动数列 引言 今天是大年三十&#xff0c;提前祝大家新的一年天天开心&#xff0c;事事如意&#xff0c;过年把身体精神修养好后&#xff0c;年后继续朝着目标奋斗&#xff0c;然后加油吧&#xff01; 一、最长上升子序列 标签&…

Android截屏方法

// 截屏方法private void getSnapshot() {wView.measure(View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED), View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED));wView.layout(0, 0, wView.getMeasuredWidth(), wView.getMeasuredHeight(…

U3D记录之FBX纹理丢失问题

今天费老大劲从blender建了个模型&#xff0c;然后导出进去unity 发现贴图丢失 上网查了一下 首先blender导出要改设置 这个path mode要copy 然后unity加载纹理也要改设置 这里这个模型的纹理load要改成external那个模式 然后就有了&#xff0c;另外这个导出还有好多选项可…

Python判断列表A中是否有元素出现在了列表B中

目录 1. 问题重述2. 问题求解2.1 暴力法2.2 哈希表法2.3 集合法 3. 总结 1. 问题重述 给定两个列表 A A A 和 B B B&#xff0c;它们的长度分别为 n n n 和 m m m。我们要检查的是&#xff0c;是否存在 x ∈ A x\in A x∈A&#xff0c;使得 x ∈ B x\in B x∈B。 以下介…

Java项目maven打包的包名设置(finalname标签的使用)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

C#用Array类的Reverse方法反转数组中元素

目录 一、Array.Reverse 方法 1.重载 2.Reverse(Array, Int32, Int32) 3. Reverse(Array) 4.Reverse(T[]) 5. Reverse(T[], Int32, Int32) 二、实例 1.Array.Reverse 方法4种重载方法综合实例 2.Reverse(Array)方法的实例 一、Array.Reverse 方法 反转一维 Array 或部…

wireshark分析数据包:追踪流

打开追踪流的界面 方法 1 方法 2 选中数据包&#xff0c;右键弹出菜单 说明&#xff1a; 流内容的显示顺序和它在网络上出现的顺序相同。不可打印的字符被点代替。从客户端到服务器的流量被标记为红色&#xff0c;而从服务器到客户端的流量被标记为蓝色。这些颜色可以通过下…

numpy基础之transpose

1 numpy基础之transpose 用法 ndarray.transpose(*axes)描述 根据axes将ndarray数组进行转置。 入参 axes&#xff1a;可选&#xff0c;元组或列表。若指定&#xff0c;则元素个数必须为数组轴大小(ndarray.ndim)&#xff0c;元素值的范围为[0,1,2,…,ndarray.ndim-1]&…

Python(22)正则表达式中的“限定符”

大家好&#xff01;我是码银&#x1f970; 欢迎关注&#x1f970;&#xff1a; CSDN&#xff1a;码银 公众号&#xff1a;码银学编程 获取资源&#xff1a;公众号回复“python资料” 限定符功能?匹配前面的字符0次或1次匹配前面的字符1次或多次*匹配前面的字符0次或多次{n…

R语言rmarkdown使用

1、安装 install.packages(rmarkdown) library(rmarkdown) install.packages(tinytex) tinytex::install_tinytex() 2、新建R Markdown 3、基本框架 红色框内为YAML&#xff1a;包括标题、作者和日期等 黄色框内为代码块&#xff1a;执行后面的代码&#xff0c;并可以设置展…

适用于 Windows 的 6 款 iPhone 数据恢复软件

数据恢复 已经取得了长足的进步。从仅提供恢复数据的可能性到保证数据恢复&#xff0c;有许多适用于 Windows的第三方 iPhone 数据恢复软件。 大多数软件都是高级工具&#xff0c;但是提供了出色的数据恢复解决方案。从iPhone恢复数据非常简单。 只需将 iPhone 连接到您的计算…

11 串口发送应用之使用状态机实现多字节数据发送

1. 使用串口发送5个字节数据到电脑 uart协议规定&#xff0c;发送的数据位只能是6&#xff0c;7&#xff0c;8位&#xff0c;如果数据位不符合&#xff0c;接收者接收不到数据。所以我们需要将40位数据data分为5个字节数据分别发送&#xff0c;那么接收者就能通过uart协议接收…

开源的直播平台

​​​​​​直播平台系统界面介绍 开源一套直播平台 私信可获取源码

C语言使⽤ scanf()函数应注意的问题是什么?

一、问题 scanf()函数的基本格式和格式符&#xff0c;在使⽤时应注意什么问题呢&#xff1f; 二、解答 那么具体该注意哪些问题呢&#xff1f;下⾯来看⼀下⽐较常见的⼀些错误。 1、不能控制精度 与 printf()函数不同&#xff0c;scanf()函数输⼊实数时&#xff0c;是不能控制…

qt/c++实现拓扑排序可视化

&#x1f482; 个人主页:pp不会算法^ v ^ &#x1f91f; 版权: 本文由【pp不会算法v】原创、在CSDN首发、需要转载请联系博主 &#x1f4ac; 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦 实现功能 1、选择文件导入初始数据 2、逐步演示 3、排序完成输出…

多线程基础详解(看到就是赚到)

&#x1f3a5; 个人主页&#xff1a;Dikz12&#x1f4d5;格言&#xff1a;那些在暗处执拗生长的花&#xff0c;终有一日会馥郁传香欢迎大家&#x1f44d;点赞✍评论⭐收藏 目录 创建线程 1.创建类继承Thread,重写run() 2.实现Runnable,重写run() 3.继承Thread,使用匿名内部类 …

问题:A注册会计师必须在期中实施实质性程序的情形是()。 #学习方法#其他

问题&#xff1a;A注册会计师必须在期中实施实质性程序的情形是&#xff08;&#xff09;。 A&#xff0e;甲公司整体控制环境不佳 B&#xff0e;将期中实质性程序所获证据与期末数据进行比较 C&#xff0e;评估的认定层次重大错报风险很高 D&#xff0e;没有把握通过在期中…