算法通关村第十六关|白银|滑动窗口经典

1.最长子串

1.1 无重复字符的最长子串

原题:力扣3.

使用 HashMap ,将字符和最后一次出现的索引存储起来。

public int lengthOfLongestSubstring(String s) {if (s.length() == 0) {return 0;}HashMap<Character, Integer> map = new HashMap<Character, Integer>();int max = 0;int left = 0;for (int right = 0; right < s.length(); right++) {if (map.containsKey(s.charAt(right))) {left = Math.max(left, map.get(s.charAt(right)) + 1);}map.put(s.charAt(right), right);max = Math.max(max, right - left + 1);}return max;
}

1.2 至多包含两个不同字符的最长子串

原题:力扣159.

public int lengthOfLongestSubstringTwoDistinct(String s) {if (s.length() < 3) {return s.length();}int left = 0, right = 0;HashMap<Character, Integer> hashmap = new HashMap<>();int maxLen = 2;while (right < s.length()) {if (hashmap.size() < 3) {hashmap.put(s.charAt(right), right++);}if (hashmap.size() == 3) {int del_index = Collections.min(hashmap.values());hashmap.remove(s.charAt(del_index));left = del_index + 1;}maxLen = Math.max(maxLen, right - left);}return maxLen;
}

*1.3 至多包含 K 个不同字符的最长子串

原题:力扣340.

public int lengthOfLongestSubstringDistinct(String s, int k) {if (s.length() < k + 1) {return s.length();}int left = 0, right = 0;HashMap<Character, Integer> hashmap = new HashMap<>();int maxLen = k;while (right < s.length()) {if (hashmap.size() < k + 1) {hashmap.put(s.charAt(right), right++);}if (hashmap.size() == k + 1) {int del_index = Collections.min(hashmap.values());hashmap.remove(s.charAt(del_index);left = del_index + 1;}maxLen = Math.max(maxLen, right - left);}return maxLen;
}

2.长度最小的子数组

原题:力扣209.

public int minSubArrayLen(int target, int[] nums) {int left = 0, right = 0, sum = 0, min = Integer.MAX_VALUE;while (right < nums.length) {sum += nums[right++];while (sum >= target) {min = Math.min(min, right - left);sum -= nums[left++];}}return min == Integer.MAX_VALUE ? 0 : min;
}

3.盛水最多的容器

原题:力扣11.

双指针向中间移动直到碰撞。

public int maxArea(int[] height) {int i = 0, j = height.length - 1, res = 0;while (i < j) {res = height[i] < height[j] ?Math.max(res, (j - i) * height[i++]) :Math.max(res, (j - i) * height[j--]);}return res;
}

4.寻找子串异位词(子串排列)

如果两个字符串仅仅是字母出现的位置不一样,则两者互为对方的一个排列,也叫做异位词。

4.1 字符串的排列

原题:力扣567.

这道题要求判断 s2 是否包含 s1 的排列。

public boolean checkInclusion(String s1, String s2) {int len1 = s1.length(), len2 = s2.length();if (len1 > len2) {return false;}// 统计每种字符出现次数int[] charArray1 = new int[26];int[] charArray2 = new int[26];// 先读第一段// 滑动窗口长度固定为 len1for (int i = 0; i < len1; i++) {// 哪个字符出现了,数组中对应的位置就加 1charArray1[s1.charAt(i) - 'a']++;charArray2[s2.charAt(i) - 'a']++;}// 比较第一段数组中字符是否数目相同if (Arrays.equals(charArray1, charArray2)) {return true;}// 开始移动窗口for (int right = len1; right < len2; right++) {// charArray1 已经存好了,不需要再变动charArray2[s2.charAt(right) - 'a']++;int left = right - len1;charArray2[s2.charAt(left) - 'a']--;if (Arrays.equals(charArray1, charArray2)) {return true;}}return false;
}

4.2 找到字符串中所有字母异位

原题:力扣438.

要求将所有符合条件的排列的起始索引返回。

public List<Integer> findAnagrams(String s, String p) {List<Integer> res = new ArrayList<>();if (s.length() < p.length()) {return res;}// 还是用滑动窗口做,但是这次记录起始索引int left = 0;int[] charArray1 = new int[26];int[] charArray2 = new int[26];for (int i = 0; i < p.length(); i++) {charArray1[s.charAt(i) - 'a']++;charArray2[p.charAt(i) - 'a']++;}if (Arrays.equals(charArray1, charArray2)) {res.add(left);}for (int right = p.length(); right < s.length(); right++) {charArray1[s.charAt(right) - 'a']++;charArray1[s.charAt(left) - 'a']--;left++;if (Arrays.equals(charArray1, charArray2)) {res.add(left);}}return res;
}

如果对您有帮助,请点赞关注支持我,谢谢!❤
如有错误或者不足之处,敬请指正!❤
个人主页:星不易 ❤
算法通关村专栏:不易|算法通关村 ❤

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

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

相关文章

js数组合并的方法,以及各方法的区别

需求 array1 [1,2,3] array2 [4,5,6] 合并俩数组 打印结果为 [1,2,3,4,5,6] 思路 方法一 使用concat()方法 concat()方法可以将多个数组合并成一个新数组&#xff0c;不会修改原始数组。 优点 它可以合并任意数量的数组&#xff0c;并且可以在合并时添加新的元…

【云备份】客户端模块

33. 客户端数据管理模块实现-数据信息设计 客户端要实现的功能是对指定文件夹中的文件自动进行备份上传。但是并不是所有的文件每次都需要上传&#xff0c;我们需要能够判断&#xff0c;哪些文件需要上传&#xff0c;哪些不需要&#xff0c;因此需要将备份的文件信息给管理起来…

linux 命令 tmux 用法详解

一、tmux 解决的痛点&#xff08;screen命令一样可以解决&#xff0c;但是tmux功能更强大&#xff09; 痛点一&#xff1a;大数据传输的漫长一夜 相信做过 Linux 服务运维的同学&#xff0c;都用 scp 进行过服务器间的大文件网络传输。一般这需要很长的时间&#xff0c;这期间…

自动化集成有哪些典型应用场景?

为什么要做自动化场景集成&#xff1f; 主要分为以下几点&#xff1a; 提高效率/减少错误&#xff1a;减少人工操作、人为错误、人力成本&#xff0c;提高生产效率、生产质量和稳定性。 提高可靠性&#xff1a;提高系统的可靠性和稳定性&#xff0c;减少系统故障和停机时间。…

【云备份】项目介绍

1. 云备份认识 自动将本地计算机上指定文件夹中需要备份的文件上传备份到服务器中。并且能够随时通过浏览器进行查看并且下载&#xff0c;其中下载过程支持断点续传功能&#xff0c;而服务器也会对上传文件进行热点管理&#xff0c;将非热点文件进行压缩存储&#xff0c;节省磁…

golang使用es,报错Elasticsearch health check failed

今天golang代码里调用es&#xff0c;结果一直报错。报错内容 ElasticsearchRestHealthIndicator : Elasticsearch health check failed然后又去es管理端看&#xff0c;明明节点是绿色的&#xff0c;估计是golang的这个有问题&#xff0c;时间紧迫&#xff0c;我就直接关掉了健…

【网络安全】-《网络安全法》制定背景和核心内容

文章目录 1. 背景介绍1.1 数字时代的崛起1.2 中国网络安全形势 2. 《网络安全法》核心内容2.1 法律适用范围2.2 个人信息保护2.3 关键信息基础设施保护2.4 网络安全监管和应急响应2.5 网络产品和服务安全管理2.6 法律责任和处罚 3. 法律的意义和影响3.1 维护国家安全3.2 保护个…

易石无代码开发:电商平台连接CRM与客服系统,实现营销自动化

易石无代码开发的优势 易石软件以其强大的无代码开发平台&#xff0c;为电商企业提供了一种全新的业务集成手段。在激烈的市场竞争中&#xff0c;电商平台必须不断优化其运营效率和客户服务质量。易石无需复杂的API开发&#xff0c;通过简单的配置就能实现电商平台与CRM、客服…

翻硬币(第四届蓝桥杯省赛C++B组)(java版)

//翻硬币,每次都会改变两个硬币的状态 //因此我们可以从前往后枚举,s1[i] 与 s2[i] 状态不同就改变它的状态 //同时s1[i 1] 与 s2[i 1] 的状态会因此改变 // 所以继续往下枚举s1[i 1] 与 s2[i 1] //因为题目有说必须有解,因此枚举到 n - 1位的时候&#xff0c;两个字符串的…

微软推出AI助手Copilot的正式版本;ChatGPT:七位研究人员分享他们的观点

&#x1f989; AI新闻 &#x1f680; 微软推出AI助手Copilot的正式版本 摘要&#xff1a;微软宣布其AI助手Copilot正式上线&#xff0c;此前Copilot的预览版已成为很多用户的日常AI伴侣。此次上线后&#xff0c;Copilot将继续提供AI驱动的网络聊天体验&#xff0c;并具备商业…

Linux:dockerfile编写搭建mysql练习(10)

搭建了httpyum仓库 Dockerfile 主要文件 基于centos基础镜像 centos.repo yum仓库 db_init.sh mysql初始化脚本 run.sh 启动脚本 vim Dockerfile写入FROM centosMAINTAINER teacher lyRUN mkdir /etc/yum.repos.d/bak ; mv /etc/yu…

深入了解Java Period类,对时间段的精确控制

阅读建议 嗨&#xff0c;伙计&#xff01;刷到这篇文章咱们就是有缘人&#xff0c;在阅读这篇文章前我有一些建议&#xff1a; 本篇文章大概2900多字&#xff0c;预计阅读时间长需要3分钟。本篇文章的实战性、理论性较强&#xff0c;是一篇质量分数较高的技术干货文章&#x…

上机实验四 哈希表设计 西安石油大学数据结构

实验名称&#xff1a;哈希表设计 &#xff08;1&#xff09;实验目的&#xff1a;掌握哈希表的设计方法及其冲突解决方法。 &#xff08;2&#xff09;主要内容&#xff1a; 已知一个含有10个学生信息的数据表&#xff0c;关键字为学生“姓名”的拼音&#xff0c;给出此表的一…

二叉树的统一迭代法(统一模板样式)

前言&#xff1a; http://t.csdnimg.cn/WzCFU&#xff08;二叉树的前&#xff0c;中&#xff0c;后序递归与迭代法&#xff09; 在前文中我们发现迭代法实现的先中后序&#xff0c;其实风格也不是那么统一&#xff0c;除了先序和后序&#xff0c;有关联&#xff0c;中序完全就…

Leetcode 538 把二叉搜索树转换为累加树

理解题意&#xff1a; 所谓累加树&#xff1a;对于每个节点&#xff0c;将所有比它大的点累加于这一点。 而二叉搜索树&#xff1a;任何一个中间节点&#xff0c;都大于左子树任何节点&#xff0c;小于右子树所有节点。 而二叉搜索树中序排列是严格单调递增的序列。 所以二叉搜…

VBA字典与数组第八讲:数组及数组公式结果的制约性和集合性

《VBA数组与字典方案》教程&#xff08;10144533&#xff09;是我推出的第三套教程&#xff0c;目前已经是第二版修订了。这套教程定位于中级&#xff0c;字典是VBA的精华&#xff0c;我要求学员必学。7.1.3.9教程和手册掌握后&#xff0c;可以解决大多数工作中遇到的实际问题。…

Mysql内联接inner join以后数据条数比原数据表多

数据表A有500条数据&#xff0c;数据表B有600条数据&#xff0c;执行如下sql&#xff0c;预期500条结果 select * from A inner join B on A.id b.a_id;但是执行结果有520条&#xff0c; 原因&#xff1a; B中有一些c_id重复的数据&#xff0c;在与A表进行内联接的时候&…

OpenGL学习(一)绘制一个图形

本文使用Qt进行操作演示。 注意: 坐标原点位于屏幕中心 坐标参数:0.0f - 1.0f 颜色参数:0.0f - 1.0f OpenGL提供了几种用于绘制几何图形的绘制模式。下面是一些常用的绘制模式&#xff1a; 点&#xff08;GL_POINTS&#xff09;&#xff1a;绘制单个点。 线&#xff08;GL_LIN…

【云备份】服务端数据管理模块

21. 服务端工具类实现-文件实用工具类设计 不管是客户端还是服务端&#xff0c;文件的传输备份都涉及到文件的读写&#xff0c;包括数据管理信息的持久化也是如此&#xff0c;因此首先设计封装文件操作类&#xff0c;这个类封装完毕之后&#xff0c;则在任意模块中对文件进行操…

Tap虚拟网卡 (草稿)

1 概述 Tap设备通常用于虚拟化场景下&#xff0c;参考如下场景&#xff1a; 图中标注了关键函数&#xff0c;以及数据流向。 tun有两个数据接口&#xff0c; file&#xff0c;给用户态使用&#xff1b;socket&#xff0c;给内核态使用&#xff0c;例如vhost 2 异步处理 图…