【算法】滑动窗口题单——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工具代替人自动判断预期…...
8k长序列建模,蛋白质语言模型Prot42仅利用目标蛋白序列即可生成高亲和力结合剂
蛋白质结合剂(如抗体、抑制肽)在疾病诊断、成像分析及靶向药物递送等关键场景中发挥着不可替代的作用。传统上,高特异性蛋白质结合剂的开发高度依赖噬菌体展示、定向进化等实验技术,但这类方法普遍面临资源消耗巨大、研发周期冗长…...
如何在看板中体现优先级变化
在看板中有效体现优先级变化的关键措施包括:采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中,设置任务排序规则尤其重要,因为它让看板视觉上直观地体…...
在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module
1、为什么要修改 CONNECT 报文? 多租户隔离:自动为接入设备追加租户前缀,后端按 ClientID 拆分队列。零代码鉴权:将入站用户名替换为 OAuth Access-Token,后端 Broker 统一校验。灰度发布:根据 IP/地理位写…...
DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI
前一阵子在百度 AI 开发者大会上,看到基于小智 AI DIY 玩具的演示,感觉有点意思,想着自己也来试试。 如果只是想烧录现成的固件,乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外,还提供了基于网页版的 ESP LA…...
第一篇:Agent2Agent (A2A) 协议——协作式人工智能的黎明
AI 领域的快速发展正在催生一个新时代,智能代理(agents)不再是孤立的个体,而是能够像一个数字团队一样协作。然而,当前 AI 生态系统的碎片化阻碍了这一愿景的实现,导致了“AI 巴别塔问题”——不同代理之间…...
相机从app启动流程
一、流程框架图 二、具体流程分析 1、得到cameralist和对应的静态信息 目录如下: 重点代码分析: 启动相机前,先要通过getCameraIdList获取camera的个数以及id,然后可以通过getCameraCharacteristics获取对应id camera的capabilities(静态信息)进行一些openCamera前的…...
今日科技热点速览
🔥 今日科技热点速览 🎮 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售,主打更强图形性能与沉浸式体验,支持多模态交互,受到全球玩家热捧 。 🤖 人工智能持续突破 DeepSeek-R1&…...
嵌入式学习笔记DAY33(网络编程——TCP)
一、网络架构 C/S (client/server 客户端/服务器):由客户端和服务器端两个部分组成。客户端通常是用户使用的应用程序,负责提供用户界面和交互逻辑 ,接收用户输入,向服务器发送请求,并展示服务…...
脑机新手指南(七):OpenBCI_GUI:从环境搭建到数据可视化(上)
一、OpenBCI_GUI 项目概述 (一)项目背景与目标 OpenBCI 是一个开源的脑电信号采集硬件平台,其配套的 OpenBCI_GUI 则是专为该硬件设计的图形化界面工具。对于研究人员、开发者和学生而言,首次接触 OpenBCI 设备时,往…...
【Linux】自动化构建-Make/Makefile
前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具:make/makfile 1.背景 在一个工程中源文件不计其数,其按类型、功能、模块分别放在若干个目录中,mak…...
