“滑动窗口”算法专项训练

news2025/1/19 2:56:50

目录

题目链接:长度最小的子数组

题目描述

思路分析:滑动窗口(利用单调性,使用"同向双指针'来优化)

细节处理

画图解析

代码

题目链接:最大连续1的个数 III

题目描述

思路分析:滑动窗口(同向双指针)

细节处理

画图解析

代码

题目链接:将 x 减到 0 的最小操作数

题目描述

思路分析: 滑动窗口(同向双指针)

细节处理

画图解析

代码


题目链接:长度最小的子数组

题目描述

思路分析:滑动窗口(利用单调性,使用"同向双指针'来优化)

  1. 定义左右指针left和right
  2. right指针进入窗口
  3. while(判断是否满足窗口内部和的值大于等于目标值的条件
  4. 更新最小长度以及窗口和的值
  5. left出窗口 )

细节处理

  • 单调性规避了很多没必要的枚举行为,因为在找到满足条件的窗口和之后,right指针继续进入窗口的长度肯定比原来的大,所以找到满足条件的窗口和之后应该出窗口
  • 同向双指针指的是left和right都是往一个方向移动,不会回退 

画图解析

代码

public int minSubArrayLen(int target,int[]nums) {
        int n= nums.length,len=Integer.MAX_VALUE,sum=0;
        for (int left = 0,right=0; right < n; right++) {
            //进窗口
            sum+=nums[right];
            while (sum>=target){//判断
                len=Math.min(len,right-left+1);
                sum-=nums[left];
                left++;//出窗口
            }
        }
        return len==Integer.MAX_VALUE?0:len;
    }

题目链接:最大连续1的个数 III

题目描述

 

思路分析:滑动窗口(同向双指针)

  1. 定义左右指针left和right以及统计0的个数zero
  2. right指针进入窗口
  3. while(判断是否满足窗口内部zero的值大于等于最多反转个数k的条件
  4. left出窗口)
  5. 更新最长长度

细节处理

在找到超过反转个数的right位置时,left不用走一步就更新一次,因为在刚找到的那个位置的长度一定比left往后面一步一步走的长度长(例1比例2长)

画图解析

代码

public int longestOnes(int[] nums, int k) {
         int n=nums.length,zero=0,len=0;
        for (int right = 0,left=0; right < n; right++) {
            if(nums[right]==0) zero++;//进窗口
            while (zero>k){//判断
                if(nums[left]==0) zero--;//出窗口
                left++;
            }
            len=Math.max(len,right-left+1);
        }
        return len;
    }

题目链接:将 x 减到 0 的最小操作数

题目描述

思路分析: 滑动窗口(同向双指针)

  1. 定义左右指针left,right和数组总和sum,窗口长度len=-1
  2. right进入窗口得到temp
  3. whlie(判断sum是否大于temp
  4. 是的话left出窗口)
  5. 如果sum==target则更新结果长度len,取最大
  6. 用数组总长度-窗口满足条件的最大长度即得到结果

 

细节处理

  • 巧妙转化:遇难则反,将问题转化为求数组总和减去目标数的窗口的最长长度,数组总长度减去最长长度即可得到最小操作数。
  • 当right走到sum>=target位置时,left++,right不用回退left再走一遍,因为right还是要走到当前位置才满足条件。left需要走是因为如果sum>target,那left出窗口可能会找到sum==target

画图解析

代码

 public int minOperations(int[] nums, int x) {
         int sum=0;
        int n=nums.length;
        int len=-1;
        for (int i : nums) sum+=i;
        int target=sum-x;
//        如果x的值大于所有数之和,直接返回-1
        if(target<0) return -1;
        for (int right = 0,left=0,temp=0; right < n ; right++) {
            temp+=nums[right];//进窗口
            while (temp>target){//判断
                temp-=nums[left];
                left++;//出窗口
            }
            if(temp==target){
                len=Math.max(len,right-left+1);//更新结果
            }
        }
        if(len==-1)  return len;
        else return n-len;
    }

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

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

相关文章

面对纷繁复杂的低代码和无代码产品,开发者该如何选择?

凭借着革命性的生产力优势&#xff0c;低代码技术火爆了整个IT圈。面对纷繁复杂的低代码和无代码产品&#xff0c;开发者该如何选择&#xff1f; 在研究低代码平台的年数上&#xff0c;本人已有3年&#xff0c;也算是个低代码资深用户了&#xff0c;很多企业面临低代码选型上的…

TCP/IP(二十)TCP 实战抓包分析(四)TCP 第二次握手 SYN、ACK 丢包

一 实验二&#xff1a;TCP 第二次握手 SYN、ACK 丢包 重点&#xff1a; 通过设置 tcp_synack_retries 和 tcp_syn_retries内核参数,观察丢包的现象 ① 实验环境 iptables -t filter -I INPUT -s 172.25.2.100 -j DROPtcpdump -nni ens3 tcp and host 172.25.2.100 and por…

【算法 | 位运算No.1】leetcode268. 丢失的数字

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【手撕算法系列专栏】【Leetcode】 &#x1f354;本专栏旨在提高自己算法能力的同时&#xff0c;记录一下自己的学习过程&#xff0c;希望…

打造一个开箱即用的超级丝滑的漂亮hexo博客网站

打造一个开箱即用的超级丝滑的漂亮hexo博客网站 目录 文章目录 打造一个开箱即用的超级丝滑的漂亮hexo博客网站目录文章持续更新地址鸣谢hexo简介hexo优缺点优点缺点&#x1f44e; 没有后台管理 博客效果主题特性版本迭代1.原版版本迭代2.自己版本迭代 贡献者主题下载&#x1f…

Python中if __name__ == ‘__main__‘

1. 在Python中&#xff0c;凡是以两个下划线开头&#xff0c;两个下划线结尾的变量叫做“魔法变量”。瓦特&#xff1f;魔法变量&#xff1f;对&#xff0c;你没有听错&#xff0c;就是魔法变量。所谓魔法变量就是Python对象内置天生就有的属性变量&#xff0c;你使用这些变量前…

开关电源测试方案介绍:如何进行电源耐压测试?

耐压测试是检验电源模块、电器设备等承受过压能力的测试方法&#xff0c;同时电源模块耐压测试还可以检测出设备的绝缘性能。在电气设备的使用过程中会出现电压突然上升的情况&#xff0c;有时也会因为天气原因出现高压&#xff0c;如果耐压性能弱&#xff0c;设备绝缘能力差&a…

【Java学习之道】SQL语言的基本语法与操作

引言 对于初学者来说&#xff0c;数据库编程可能听起来有些复杂&#xff0c;但实际上&#xff0c;只要掌握了SQL语言的基本语法和操作&#xff0c;你就能够轻松地处理各种数据问题。本章将为你揭示SQL语言的魅力&#xff0c;帮助你快速入门数据库编程。 一、SQL语言简介 SQL…

Three.js柏林噪音 流动球体

代码&#xff1a;https://gitee.com/honbingitee/three-template-next.js/tree/shader/ 参考油管视频&#xff1a;https://www.youtube.com/watch?voKbCaj1J6EI 核心&#xff1a; 创建循环的图形 应用噪声 顶点按照法相偏移 CustomMaterial(): ShaderMaterial {const material…

轻松上手,制作电子期刊就这么简单

嗨&#xff0c;年轻的朋友们&#xff01;你是否想过用你的创意和热情来制作一本属于自己的电子期刊&#xff1f;现在&#xff0c;这个梦想已经触手可及&#xff01;只需要用到这款工具即可轻松上手&#xff0c;就能拥有自己的电子期刊 工具&#xff1a;FLBOOK在线制作电子杂志平…

工具类app变现难?工具类产品广告变现策略实用指南

工具类app面临着买量成本高&#xff0c;收益提升难 的困境&#xff0c;在不同的变现周期可以采用不同的变现策略。#APP广告变现# 1、合理挖掘变现场景&#xff0c;提升eCPM 工具类 App 可基于自身产品属性和用户使用习惯路径&#xff0c;相应地选择开屏广告、信息流、横幅、…

品牌线上布局思路有哪些,品牌策略分析!

电商运营是现代企业宣推和销售产品的重要方式之一。要让品牌产品在电商节点&#xff0c;实现流量获取&#xff0c;就必须制定详细有效的品牌策略。今天为大家带来品牌线上布局思路有哪些&#xff0c;品牌策略分析&#xff01; 不同于线下销售广告&#xff0c;针对电商平台&…

浅谈压力测试的重要目标及意义

随着互联网应用的快速发展&#xff0c;软件系统的稳定性和性能成为了用户和企业关注的焦点。用户期望应用程序能够在高负载下依然保持稳定和高效。为了满足这一需求&#xff0c;压力测试成为了不可或缺的一环。本文将探讨压力测试的重要性以及如何进行压力测试。 一、压力测试的…

[正式学习java③]——字符串在内存中的存储方式、为什么字符串不可变、字符串的拼接原理,键盘录入的小细节。

一、字符串 1.字符串在内存中的存储方式 &#x1f525;在java中&#xff0c;内存中有两个地方可以存储字符串&#xff0c;一个是字符串池&#xff0c;一个是堆内存&#xff0c;串池中的字符串不会重复&#xff0c;而堆中的字符串每次都会开辟一块新的空间&#xff0c;因为维护…

Python武器库开发-基础篇(三)

基础篇(三) 函数 下面是一个打印问候语的简单函数&#xff0c;名为greet_user() &#xff1a; greeter.py def greet_user():"""显示简单的问候语"""print("Hello!")greet_user()这个示例演示了最简单的函数结构。第一行的代码行使…

优雅而高效的JavaScript——防抖和节流

&#x1f60a;博主&#xff1a;小猫娃来啦 &#x1f60a;文章核心&#xff1a;优雅而高效的JavaScript——防抖和节流 文章核心 引言事件处理的性能问题防抖&#xff1a;延迟触发事件基本原理实现防抖的代码示例实际应用场景举例 节流&#xff1a;限制事件触发频率基本原理实现…

传输层协议(TCP/UDP协议)

全文目录 端口号端口号范围划分 传输层UDP协议特点基于UDP的应用层协议 TCP协议确认应答机制&#xff08;可靠性&#xff09;延迟应答机制超时重传机制流量控制连接管理机制TIME_WAIT 状态CLOSE_WAIT 状态拥塞控制滑动窗口 TCP、UDP对比TCP的listen第二个参数 端口号 在套接字…

【算法设计zxd】第5章分治法

目录 分治算法策略的设计模式 分治思想&#xff1a; 分治算法求解问题的步骤&#xff1a; 设计模式 算法分析 二分查找算法 思考题 计算模型&#xff1a; 时间复杂度分析&#xff1a; 代码&#xff1a; 分治*大数乘法&#xff1a; 【例5-2】设X, Y是两个n位的十进制…

掌动智能分析云性能监控的重要性

云计算已成为现代企业的核心基础设施&#xff0c;它为企业提供了灵活性、可扩展性和成本效益。然而&#xff0c;将业务迁移到云上并不意味着问题就此消失。企业必须仍然保持对其云基础设施和应用程序的严格监控&#xff0c;以确保其性能和可靠性。本文将深入探讨企业云性能监控…

共享模型之管程

1、共享带来的问题 线程出现问题的根本原因是因为线程上下文切换&#xff0c;导致线程里的指令没有执行完就切换执行其它线程了&#xff0c;下面举一个例子 Test13.java static int count 0;public static void main(String[] args) throws InterruptedException {Thread t1 …

学习最优化课程中的一些疑惑

感谢gpt I: 你是一个数学专业教授&#xff0c;请给我讲解一下卡氏积的含义 GPT: 卡氏积&#xff08;Cartesian product&#xff09;是集合论中的一个概念&#xff0c;用来描述两个集合之间的关系。假设有两个集合A和B&#xff0c;卡氏积A B定义为所有有序对 (a, b)&#xf…