一句话概括就是两个快慢指针维护的一个会移动的区间

固定大小窗口:求哪个窗口元素最大、最小、平均值、和最大、和最小
可变大小窗口:求一个序列里最大、最小窗口是什么

思路:每次窗口向右滑动一格,大小不变为k,遍历一次数组结果就出来了
- class Solution {
- public double findMaxAverage(int[] nums, int k) {
- int left = 0;
- int right = k-1;
- double sum = 0;
- for(int i = 0;i
- sum += nums[i];
- }
- double res = sum/k;
- while(right
1){ - right++;
- left++;
- sum = sum - nums[left-1] + nums[right];
- if(sum/k>res){
- res = sum/k;
- }
- }
- return res;
- }
- }
(2)最长连续递增序列

思路:窗口是递增的序列,当符合递增条件时窗口扩大,当不符合递增窗口重置为当前right位置,用一个变量来记录最长的递增子序列长度(窗口长度)
- class Solution {
- public int findLengthOfLCIS(int[] nums) {
- if(nums.length == 1){
- return 1;
- }
- int left = 0;
- int right = 0;
- int count = 1;
- int res = 1;
- while(right
1){ - if(nums[right+1]>nums[right]){
- count++;
- right++;
- }else{
- res = res
- count = 1;
- right++;
- left = right;
- }
- }
- return count > res ? count : res;
- }
- }
-
相关阅读:
ISCTF新生赛(引用传递&简单社工)
A66 STM32_HAL库函数 之 USART通用驱动 -- B -- 所有函数的介绍及使用
Spring Boot 基础使用
二十七、CANdelaStudio深入-编辑技巧(一致性检查)
【小程序项目开发 -- 京东商城】uni-app 商品分类页面(下)
YOLOV5---自己数据集制作
MYSQL:Select语句顺序
缓存击穿、穿透、雪崩和布隆过滤器
数学分析:傅里叶三角级数
解读BOT攻击,探索灵活且准确的安全之道
-
原文地址:https://blog.csdn.net/Candy___i/article/details/133234295