【算法】滑动窗口题单——4.不定长滑动窗口(求子数组个数)
文章目录
- 前言
- 2799. 统计完全子数组的数目
- 解法1——枚举右端点,移动左端点
- 解法2——枚举左端点,扩展右端点
- 713. 乘积小于 K 的子数组
- 1358. 包含所有三种字符的子字符串数目
- 2302. 统计得分小于 K 的子数组数目
- 2537. 统计好子数组的数目
- 2762. 不间断子数组(滑动窗口+)
- 解法1——TreeMap
- 解法2——单调队列
题单来源:https://leetcode.cn/problems/minimum-size-subarray-in-infinite-array/solutions/2464878/hua-dong-chuang-kou-on-shi-jian-o1-kong-cqawc/
前言
这些问题常用的方法有:
- 枚举左端点,扩展右端点。
- 枚举右端点,收缩左端点。
2799. 统计完全子数组的数目
https://leetcode.cn/problems/count-complete-subarrays-in-an-array/description/

提示:
1 <= nums.length <= 1000
1 <= nums[i] <= 2000
解法1——枚举右端点,移动左端点
class Solution {public int countCompleteSubarrays(int[] nums) {Set<Integer> s = new HashSet();for (int num: nums) s.add(num);int n = nums.length, sum = s.size(), ans = 0;Map<Integer, Integer> m = new HashMap();for (int r = 0, l = 0; r < n; ++r) {m.merge(nums[r], 1, Integer::sum);while (m.get(nums[l]) > 1) {m.merge(nums[l], -1, Integer::sum);l++;}if (m.size() == sum) ans += l + 1;}return ans;}
}
解法2——枚举左端点,扩展右端点
class Solution {public int countCompleteSubarrays(int[] nums) {Set<Integer> set = new HashSet<>();Map<Integer, Integer> map = new HashMap<>();for (int num: nums) set.add(num);int x = set.size(), n = nums.length, ans = 0;for (int l = 0, r = 0; l < n; ++l) {while (r < n && map.size() < x) map.merge(nums[r++], 1, Integer::sum);if (map.size() == x) ans += n - r + 1;map.merge(nums[l], -1, Integer::sum);if (map.get(nums[l]) == 0) map.remove(nums[l]);}return ans;}
}
713. 乘积小于 K 的子数组
https://leetcode.cn/problems/subarray-product-less-than-k/description/

提示:
1 <= nums.length <= 3 * 10^4
1 <= nums[i] <= 1000
0 <= k <= 10^6
枚举右端点,根据窗口内的乘积大小移动左端点。
当 [ l , r ] [l,r] [l,r]范围内的乘积符合条件时,一共有r-l+1个子数组符合条件计入答案,分别为 [ l + 1 , r ] , [ l + 2 , r ] , . . . , [ r , r ] [l+1,r],[l+2,r],...,[r,r] [l+1,r],[l+2,r],...,[r,r]。
class Solution {public int numSubarrayProductLessThanK(int[] nums, int k) {int n = nums.length, mul = 1, ans = 0;for (int l = 0, r = 0; r < n; ++r) {mul *= nums[r];while (l <= r && mul >= k) mul /= nums[l++];ans += r - l + 1;}return ans;}
}
1358. 包含所有三种字符的子字符串数目
https://leetcode.cn/problems/number-of-substrings-containing-all-three-characters/description/

提示:
3 <= s.length <= 5 x 10^4
s 只包含字符 a,b 和 c ·
使用 c n t [ ] cnt[] cnt[] 数组维护窗口中各个字母的数量。
枚举左端点,拓展右端点,当 [ l , r ] [l,r] [l,r]符合条件时,所有的 [ l , r ] , [ l , r + 1 ] , . . . [ l , n − 1 ] [l,r],[l,r+1],...[l,n-1] [l,r],[l,r+1],...[l,n−1]都符合条件,计入答案。
class Solution {public int numberOfSubstrings(String s) {int[] cnt = new int[3];int ans = 0, n = s.length();for (int l = 0, r = 0; l < n; ++l) {while (r < n && !check(cnt)) cnt[s.charAt(r++) - 'a']++;if (check(cnt)) ans += n - r + 1;else break; // 已经不可能有答案了cnt[s.charAt(l) - 'a']--;}return ans;}public boolean check(int[] cnt) {return cnt[0] != 0 && cnt[1] != 0 && cnt[2] != 0;}
}
2302. 统计得分小于 K 的子数组数目
https://leetcode.cn/problems/count-subarrays-with-score-less-than-k/description/

提示:
1 <= nums.length <= 10^5
1 <= nums[i] <= 10^5
1 <= k <= 10^15
枚举右端点,根据窗口情况移动左端点。
当窗口 [ l , r ] [l,r] [l,r]满足条件时,所有 [ l + 1 , r ] , [ l + 2 , r ] , . . . , [ r , r ] [l+1,r],[l+2,r],...,[r,r] [l+1,r],[l+2,r],...,[r,r]都满足条件。
class Solution {public long countSubarrays(int[] nums, long k) {long ans = 0, s = 0;for (int l = 0, r = 0; r < nums.length; ++r) {s += nums[r];while (s * (r - l + 1) >= k) s -= nums[l++];ans += r - l + 1;}return ans;}
}
2537. 统计好子数组的数目
https://leetcode.cn/problems/count-the-number-of-good-subarrays/description/

提示:
1 <= nums.length <= 10^5
1 <= nums[i], k <= 10^9
哈希表记录各个元素出现的数量,cnt记录符合条件的下标对数。
枚举窗口的左端点,为了让窗口符合条件扩展右端点。(符合条件之后,所有比当前右端点更靠右的下标作为右端点一定也符合条件。)
class Solution {public long countGood(int[] nums, int k) {long ans = 0;Map<Integer, Integer> m = new HashMap<>();int n = nums.length, cnt = 0; // cnt记录下标对数// 枚举左端点,扩展右端点for (int l = 0, r = 0; l < n; ++l) {while (r < n && cnt < k) {m.merge(nums[r], 1, Integer::sum);cnt += m.get(nums[r]) - 1;r++;}if (cnt >= k) ans += n - r + 1;else break;m.merge(nums[l], -1, Integer::sum);cnt -= m.get(nums[l]);}return ans;}
}
2762. 不间断子数组(滑动窗口+)
https://leetcode.cn/problems/continuous-subarrays/description/

提示:
1 <= nums.length <= 10^5
1 <= nums[i] <= 10^9
使用滑动窗口,维护窗口内的最大值和最小值有多种方法。
解法1——TreeMap
TreeMap 会对 key 自动排序,并且有方便的 api 获取最大key和最小key。
class Solution {public long continuousSubarrays(int[] nums) {long ans = 0;int n = nums.length;TreeMap<Integer, Integer> s = new TreeMap<>();for (int l = 0, r = 0; r < n; ++r) {s.merge(nums[r], 1, Integer::sum);while (s.lastKey() - s.firstKey() > 2) {s.merge(nums[l], -1, Integer::sum);if (s.get(nums[l]) == 0) s.remove(nums[l]);l++;}ans += r - l + 1;}return ans;}
}
解法2——单调队列
两个单调队列分别维护窗口中的最大值和最小值
class Solution {public long continuousSubarrays(int[] nums) {long ans = 0;// dq1从大到小,dq2从小到大Deque<Integer> dq1 = new ArrayDeque(), dq2 = new ArrayDeque();for (int i = 0, j = 0; i < nums.length; ++i) {// 处理两个单调队列while (!dq1.isEmpty() && nums[i] > nums[dq1.peekLast()]) dq1.pollLast();while (!dq2.isEmpty() && nums[i] < nums[dq2.peekLast()]) dq2.pollLast();dq1.offerLast(i);dq2.offerLast(i);while (nums[dq1.peekFirst()] > nums[dq2.peekFirst()] + 2) {if (dq1.peekFirst() < dq2.peekFirst()) {j = dq1.peekFirst() + 1;dq1.pollFirst();}else {j = dq2.peekFirst() + 1;dq2.pollFirst();}}ans += i - j + 1;}return ans;}
}
相关文章:
【算法】滑动窗口题单——4.不定长滑动窗口(求子数组个数)
文章目录 前言2799. 统计完全子数组的数目解法1——枚举右端点,移动左端点解法2——枚举左端点,扩展右端点 713. 乘积小于 K 的子数组1358. 包含所有三种字符的子字符串数目2302. 统计得分小于 K 的子数组数目2537. 统计好子数组的数目2762. 不间断子数组…...
CMake aux_source_directory 学习
如下,prj是空文件夹; add.h; #include <iostream>using namespace std;int add1(int a, int b); num.h; int num1100; int num2301; add.cpp; #include "add.h"int add1(int i, int j) {return i j; } main.cpp&#x…...
Mybatis中延迟加载~
延迟加载: 等一会加载,在多表关联查询操作的时候可以使用到的一种方案,如果是单表操作就完全没有延迟加载的概念。 多表查询例如,查询用户和部门信息,如果我们仅仅只是需要用户的信息,而不需要用户对应的…...
【C语言】memmove()函数(拷贝重叠内存块函数详解)
🦄个人主页:修修修也 🎏所属专栏:C语言 ⚙️操作环境:Visual Studio 2022 目录 一.memmove()函数简介 1.函数功能 2.函数参数 1>.void * destination 2>.onst void * source 3>.size_t num 3.函数返回值 4.函数头文件 二.memmove()函数…...
04-流媒体-ffmpeg.c源码分析
ffmpeg.c是一个使用ffmpeg库的参考代码,实现了视频格式转换的功能,类似于我们常用的格式工产,源代码的的目录是: ffmpeg-4.2.2/fftools/ffmpeg.c 和前面的ffplay一样,我们分析其源代码,主要只是为了让读者了解ffmpeg.c此文件的大概流程,并且熟悉常用的ffmpeg库的API。 下…...
迭代器 Iterator
迭代器是一种设计模式,它用于遍历集合或容器中的元素,能够访问集合的元素而无需关心集合的内部结构: 特点: 封装集合访问:迭代器封装了对集合元素的访问,通过迭代器访问集合中的元素,而无需了…...
掌握CSS Flexbox,打造完美响应式布局,适配各种设备!
🎬 江城开朗的豌豆:个人主页 🔥 个人专栏 :《 VUE 》 《 javaScript 》 📝 个人网站 :《 江城开朗的豌豆🫛 》 ⛺️ 生活的理想,就是为了理想的生活 ! 目录 ⭐ 专栏简介 📘 文章引言 基…...
FlutterUnit 周边 | 收录排序算法可视化
theme: cyanosis 1. FlutterUnit 更新:排序算法可视化 排序算法可视化是用视图层表现出算法执行过程中排序的过程,感谢 编程的平行世界 在 《十几种排序算法的可视化效果,快来看看!👀》》 一文中提供的算法支持。我进行…...
代码随想录Day30 贪心05 LeetCode T435无重叠区间 T763划分字母区间 T56 合并区间
LeetCode T435 无重叠区间 题目链接:435. 无重叠区间 - 力扣(LeetCode) 题目思路: 这题思路和昨天的打气球类似,我们需要按照左区间或者右区间进行排序,然后哦判断第i个区间的左端点和第i-1个区间的右端点的大小关系,,如果大于等于,那么就无需操作,一旦…...
发展高质量存储力,中国高科技力量聚浪成潮
中国信息通信研究院指出,在全球数字化转型与产业变革的浪潮下,算力正在成为改变全球竞争格局的关键力量。而根据最新的《算力基础设施高质量发展行动计划》,算力是集信息计算力、数据存储力和网络运载力于一体的新型生产力。当前,…...
修改svc的LoadBalancer的IP引发的惨案
文章目录 背景修改externalIPs的操作api-server报错日志挽救教训 背景 k8s集群没有接外部负载均衡,部署istio的时候ingressgateway一直pending。 于是手动修改了这个lb svc的externalIP,于是k8s就崩了,如何崩的,且听我还道来。 …...
2520. 统计能整除数字的位数
2520. 统计能整除数字的位数 class Solution {public int countDigits(int num) {int res 0;int o num;while (num > 0) {if (o % (num % 10) 0) {res 1;}num num / 10;}return res;} }...
BeanUtils.copyProperties的用法
常见场景 我们如果有两个具有很多相同属性名的JavaBean对象a和b,想把a中的属性赋值到b,例如 接口中将接收到的前端请求参数XxxReqVo,我们想把这个入参转化为XxxQuery对象作为数据库的查询条件对象 传统做法是手动set,即 XxxQuery xxxQuer…...
【RabbitMQ 实战】12 镜像队列
一、镜像队列的概念 RabbitMQ的镜像队列是将消息副本存储在一组节点上,以提高可用性和可靠性。镜像队列将队列中的消息复制到一个或多个其他节点上,并使这些节点上的队列保持同步。当一个节点失败时,其他节点上的队列不受影响,因…...
PyCharm社区版安装
PyCharm社区版安装 到中国官网下载 https://www.jetbrains.com/zh-cn/pycharm/download/?sectionwindows 首次创建项目,会自动下载安装Python 3.9 社区版的区别 社区版的区别...
【LeetCode每日一题合集】2023.10.16-2023.10.22(只出现一次的数字Ⅲ)
文章目录 260. 只出现一次的数字 III⭐(异或)🐂2652. 倍数求和解法1——枚举模拟解法2—— O ( 1 ) O(1) O(1)容斥原理相似题目——1201. 丑数 III(二分查找容斥原理) 2530. 执行 K 次操作后的最大分数解法1——贪心优…...
尚硅谷大数据项目《在线教育之实时数仓》笔记003
视频地址:尚硅谷大数据项目《在线教育之实时数仓》_哔哩哔哩_bilibili 目录 第7章 数仓开发之ODS层 P015 第8章 数仓开发之DIM层 P016 P017 P018 P019 01、node001节点Linux命令 02、KafkaUtil.java 03、DimSinkApp.java P020 P021 P022 P023 第7章 数…...
【Linux】部署单体项目以及前后端分离项目(项目部署)
一、简介 以下就是Linux部署单机项目和前后端分离项目的优缺点,希望对你有所帮助。 1、Linux部署单机项目: 优点: 1.简化了系统管理:由于所有服务都在同一台机器上运行,因此可以简化系统管理和维护。 2.提高了性能&a…...
设计模式之门面模式
前言 什么是门面模式 门面模式是一种结构型设计模式,它提供了一个统一的接口,用来访问子系统中的一群接口。它定义了一个高层接口,让子系统更容易使用。这种模式常用于将一个复杂的子系统封装成一个简单的接口,使得客户端可以方…...
Postman的使用
Postman的使用 Postman断言Postman常用断言1、断言响应状态码2、断言包含某个字符串3、断言JSON数据4、Postman断言工作原理 Postman关联Postman自动关联创建环境 3、Postman参数化CSV文件JSON文件1、用例集的导入导出2、环境导出 Postman断言 让Postman工具代替人自动判断预期…...
【Linux】shell脚本忽略错误继续执行
在 shell 脚本中,可以使用 set -e 命令来设置脚本在遇到错误时退出执行。如果你希望脚本忽略错误并继续执行,可以在脚本开头添加 set e 命令来取消该设置。 举例1 #!/bin/bash# 取消 set -e 的设置 set e# 执行命令,并忽略错误 rm somefile…...
论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)
HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...
Java 8 Stream API 入门到实践详解
一、告别 for 循环! 传统痛点: Java 8 之前,集合操作离不开冗长的 for 循环和匿名类。例如,过滤列表中的偶数: List<Integer> list Arrays.asList(1, 2, 3, 4, 5); List<Integer> evens new ArrayList…...
Mac软件卸载指南,简单易懂!
刚和Adobe分手,它却总在Library里给你写"回忆录"?卸载的Final Cut Pro像电子幽灵般阴魂不散?总是会有残留文件,别慌!这份Mac软件卸载指南,将用最硬核的方式教你"数字分手术"࿰…...
2025盘古石杯决赛【手机取证】
前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来,实在找不到,希望有大佬教一下我。 还有就会议时间,我感觉不是图片时间,因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...
什么是EULA和DPA
文章目录 EULA(End User License Agreement)DPA(Data Protection Agreement)一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA(End User License Agreement) 定义: EULA即…...
【JVM面试篇】高频八股汇总——类加载和类加载器
目录 1. 讲一下类加载过程? 2. Java创建对象的过程? 3. 对象的生命周期? 4. 类加载器有哪些? 5. 双亲委派模型的作用(好处)? 6. 讲一下类的加载和双亲委派原则? 7. 双亲委派模…...
Web后端基础(基础知识)
BS架构:Browser/Server,浏览器/服务器架构模式。客户端只需要浏览器,应用程序的逻辑和数据都存储在服务端。 优点:维护方便缺点:体验一般 CS架构:Client/Server,客户端/服务器架构模式。需要单独…...
Golang——7、包与接口详解
包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...
SQL Server 触发器调用存储过程实现发送 HTTP 请求
文章目录 需求分析解决第 1 步:前置条件,启用 OLE 自动化方式 1:使用 SQL 实现启用 OLE 自动化方式 2:Sql Server 2005启动OLE自动化方式 3:Sql Server 2008启动OLE自动化第 2 步:创建存储过程第 3 步:创建触发器扩展 - 如何调试?第 1 步:登录 SQL Server 2008第 2 步…...
