当前位置: 首页 > web >正文

[leetcode]2302.统计得分小于k的子数组

1.题目

2.事例

3.数据规模

4.思路(滑动窗口)

4.1滑动窗口的定义

滑动窗口是一种在数组、字符串等序列数据结构上进行操作的算法技巧。以下是其定义及相关要素的详细介绍:

  • 定义:滑动窗口可以理解为在一个序列上,用一个固定大小或者大小可变的 “窗口” 进行滑动,通过不断移动窗口的位置来对序列中的元素进行分组和处理,从而解决一些涉及连续子序列的问题。
  • 窗口大小:窗口的大小可以是固定的,例如在一个数组中,定义一个大小为k的固定滑动窗口,从数组的起始位置开始,每次向右移动一位,依次考察每一个长度为k的子数组。窗口大小也可以是可变的,根据具体问题的要求和条件,窗口会动态地扩大或缩小,以满足特定的计算需求。
  • 滑动规则:通常情况下,滑动窗口从序列的一端开始,按照一定的步长逐步向另一端滑动。每次滑动时,窗口会舍弃序列中最前面的一个元素(如果窗口大小固定),同时纳入序列中当前位置的下一个元素,以此来更新窗口内的元素集合。
  • 应用场景:常用于解决字符串匹配、数组求和、寻找最长或最短子序列等问题。例如,在字符串中查找包含特定字符集合的最小子串问题,就可以使用滑动窗口算法。通过不断调整窗口的大小和位置,找到满足条件的最小子串。

滑动窗口算法通过巧妙地利用窗口的滑动和元素的增减,避免了对所有可能子序列的暴力枚举,从而降低了算法的时间复杂度,提高了计算效率。

4.2本题思路

这个题目可以用滑动窗口的思想去解决,首先是可以从左到右去进行窗口的扩张,如果窗口里面的值*长度<k就继续向右扩大窗口,如果已经>=k了那么就停止向右扩张,并且将窗口左边界向右进行收缩,直到重新恢复到合法状态,此时把左边界确定,然后右边界重新扩张,循环上述过程即可得到答案!

5.代码

class Solution {
public:long long countSubarrays(vector<int>& nums, long long k) {int l=0,r=0;long long sum=0;long long ans=0;while(r<nums.size()){sum+=nums[r];r++;//cout<<"------"<<(r-l)*sum<<endl;if((r-l)*sum>=k){while(l<r){sum-=nums[l];l++;if((r-l)*sum<k){ans+=(r-l);break;}}}else {ans+=(r-l);//cout<<r-l<<endl;}}//ans+=(r-l);return ans;}
};

感谢大家观看,如果有任何想要交流的都可以评论区讨论!

http://www.xdnf.cn/news/2672.html

相关文章:

  • HTML5 WebSocket:实现高效实时通讯
  • Win11安装Ubuntu20.04简记
  • 软件工程(二):开发模型
  • 传统农耕展陈如何突破?数字多媒体能否重构文化体验边界?
  • 为什么MySQL推荐使用自增主键?
  • 鼠标滚动字体缩放
  • deepseek对IBM MQ SSL 证书算法的建议与解答
  • vue跨域问题总结笔记
  • 论文阅读_Citrus_在医学语言模型中利用专家认知路径以支持高级医疗决策
  • 2025 SAP专精特新企业高峰论坛 | 工博科技以SAP公有云+AI赋能新质生产力​
  • Linux系统管理与编程14:Shell变量及定制bash登录界面
  • 目标检测YOLO实战应用案例100讲- 无人机平台下露天目标检测与计数
  • 铭记之日(3)——4.28
  • 【知识科普】今天聊聊CDN
  • Go 1.24 is released(翻译)
  • 30天通过软考高项-第六天
  • Ubuntu18.04安装IntelliJ IDEA2025步骤
  • 鸿蒙 长列表加载性能优化
  • 全面解析DeepSeek算法细节(2) —— 多令牌预测(Multi Token Prediction)
  • 【UserDetailsService】
  • Axios 传参与 Spring Boot 接收参数完全指南
  • 对VTK中的Volume Data体数据进行二维图像处理
  • JVM 自动内存管理
  • 推荐一个微软官方开源浏览器自动化工具,可以用于UI自动化测试、爬虫等,具备.Net、Java、Python等多个版本!
  • 搭建 Spark YARN 模式集群指南
  • 服务器硬件老化导致性能下降的排查与优化
  • 并发设计模式实战系列(8):Active Object
  • Axure疑难杂症:利用中继器制作三级下拉菜单(逻辑判断进阶)
  • CSS 预处理器与模块化:Sass/LESS 实战技巧
  • 基于 Spring Boot 瑞吉外卖系统开发(九)