python|滑动窗口问题

news/2025/3/16 16:28:49/文章来源:https://www.cnblogs.com/luminescence/p/18775188

问题描述

滑动窗口是一种用于解决数组或字符串中子区间问题的有效算法技巧,尤其适用于需要处理连续区间的问题。它通过维护一个动态的窗口(通常由两个指针表示左右边界),在遍历过程中调整窗口的大小或位置,从而高效地解决问题。以下是滑动窗口的两种常见类型及Python实现示例:


一、滑动窗口的两种类型

  1. 固定大小的窗口
    窗口长度固定,通过滑动窗口计算特定值(如最大值、平均值等)。

  2. 动态调整的窗口
    窗口长度根据条件动态变化(如无重复字符的最长子串)。


二、固定大小窗口示例:连续子数组的最大平均值

问题:给定数组 nums 和整数 k,找到长度等于 k 的连续子数组的最大平均值。

算法步骤

  1. 计算初始窗口的和。
  2. 滑动窗口,每次减去左端元素,加上右端新元素。
  3. 更新最大值。

Python代码

def find_max_average(nums, k):window_sum = sum(nums[:k])max_sum = window_sumfor i in range(k, len(nums)):window_sum += nums[i] - nums[i - k]max_sum = max(max_sum, window_sum)return max_sum / k# 示例
nums = [1, 12, -5, -6, 50, 3]
k = 4
print(find_max_average(nums, k))  # 输出 12.75(子数组 [12, -5, -6, 50])

三、动态窗口示例:无重复字符的最长子串

问题:给定字符串 s,找到其中不含有重复字符的最长子串的长度。

算法步骤

  1. 使用左右指针定义窗口,用哈希表记录字符的最新位置。
  2. 右指针不断右移,若字符重复,更新左指针到重复位置的下一个。
  3. 更新最大窗口长度。

实现

def length_of_longest_substring(s):char_map = {}  # 记录字符最后出现的位置left = max_len = 0for right, char in enumerate(s):if char in char_map and char_map[char] >= left:left = char_map[char] + 1  # 移动左指针避免重复char_map[char] = rightmax_len = max(max_len, right - left + 1)return max_len# 示例
s = "abcabcbb"
print(length_of_longest_substring(s))  # 输出 3("abc")

四、滑动窗口的适用场景

  1. 连续子数组/子串问题
    如最大和、最小长度、平均值等。
  2. 需要高效遍历的区间问题
    将时间复杂度从暴力法的 O(n²) 优化到 O(n)。
  3. 常见题目
    • 最小覆盖子串(LeetCode 76)
    • 长度最小的子数组(LeetCode 209)
    • 字符串的排列(LeetCode 567)

关键点总结

  • 双指针:滑动窗口通常由左右指针 (left, right) 定义。
  • 哈希表辅助:用于快速判断重复或统计字符频率。
  • 边界条件:注意处理空输入或无效参数(如 k=0)。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt利用QScrollArea和QLabel实现滚轮完整显示OpenCV图片大小

解决三个常见问题,满足大部分UI界面需求。1、加载图像尺寸过大(大于窗口尺寸),在窗口自适应缩放显示大小,不改变宽高比例。2、加载图像尺寸小于窗口尺寸,使图像对齐居中显示在窗口。3、加载图像尺寸过大(大于窗口尺寸),不对图像进行缩放显示,而是在窗口产生滚轮来显示…

MYSQL-DQL操作

基本查询:查询特定列: select name,entrydate from tb_emp; 查询所有: select * from tb_emp; 查询并起别名: select name as bbb,entrydate as aaa from tb_emp;(as可省略) 去除重复记录: select distinct job from tb_emp; 条件查询:点击查看代码 select * from tb_emp where…

第二章练习题

2.1 点击查看代码 TempStr = input("请输入带有符号的温度值:") if isinstance(TempStr, str) and TempStr[-1] in [F, f]:C = int((float(TempStr[0:-1]) - 32) / 1.8)print(f"转换后的温度是{C}C") elif isinstance(TempStr, str) and TempStr[-1] in […

DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具

DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具DBeaver Ultimate Edtion 25.0 Multilingual (macOS, Linux, Windows) - 通用数据库工具 One tool for all data sources 请访问原文链接:https://sysin.org/blog/dbeaver/ 查看最新版。原…

book_77_78作业

第2章程序练习题 2.1改造温度转换的输入(不会) 2.2汇率转换 2.3重量转换 2.4彩色蟒蛇 2.5等边三角形 2.6叠加等边三角形 2.7六角形 2.8正方形螺旋

[I.2]个人作业:软件案例分析

项目 内容这个作业属于哪个课程 2025春季软件工程(罗杰、任健)这个作业的要求在哪里 [I.2]个人作业:软件案例分析我在这个课程的目标是 在PSP中精进个人代码技术,在TSP中提高团队合作凝聚力这个作业在哪个具体方面帮助我实现目标 分析市场上的软件案例,全面地了解软件工程的…

Tailscale subnet-on-android

前言啊哈,前段时间提了个issue,然后开发者那边回复了 再过了一段事件,合并了。Jan 17合并的,Feb 4发布的,那我倒要看看有没有新东西。不错不错,新功能加上了。 subnet有什么用 有人要问了,你安卓又不是路由器,搞个subnet干啥? 但是安卓可以开热点啊,尤其是在外面的网…

根据索引进行MySQL查询的简单优化

查询优化SQL让SQL尽量可以命中索引,可以提示查询的效率(但是数据库如果不走索引的速度较快,就不会去走索引)最左匹配法则由于联合索引中包括了多个列,那么对于这多个列的匹配就有一定的规则,就是最左匹配法则, 在使用联合索引时,必须满足从左边开始匹配索引列。假设现在…

FastAPI依赖注入:参数共享与逻辑复用

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长第一章:依赖注入核心原理 1.1 依赖树构建机制 from fastapi import Dependsdef auth_service():return OAuth2Scheme()def db_conn(auth: dict = Depends(auth_service)):return Database(creds=auth)@app.get(&q…

洛谷-P1449 后缀表达式

重操旧业~ 本菜鸡看到题就只会想到数组,但后来发现不可行,出去俩元素,还得进来一个元素,不好调o(╥﹏╥)o emm...但还是有所收获的,2转2,利用2-0,而不是直接强制int转换哦 同时也发现被题中举的例子迷惑了,数字可不一定是个位数! 1、此题采用栈和二叉树的后序遍历思想(…

DQL(查询语句)

简单查询 查询一个字段 select 字段名 from 表名; 查询多个字段 select 字段名1,字段名2,...,字段名 from 表名; 查询全部字段 ①在查询多个字段中,将所有的字段名写入 ②select * from 表名;————效率低,可读性差,因为将星号转化为所有字段名需要耗费一定时间,所…

PTA

​ 题目描述 小轿车中有一个系统随时监测四个车轮的胎压,如果四轮胎压不是很平衡,则可能对行车造成严重的影响。让我们把四个车轮 —— 左前轮、右前轮、右后轮、左后轮 —— 顺次编号为 1、2、3、4。本题就请你编写一个监测程序,随时监测四轮的胎压,并给出正确的报警信息。…