0

0

Python 滑动窗口算法实现与性能分析

舞夢輝影

舞夢輝影

发布时间:2026-01-27 19:26:02

|

448人浏览过

|

来源于php中文网

原创

滑动窗口优先选 deque,因其 popleft() 为 O(1),而 list.pop(0) 为 O(n);需维护单调队列时必须存下标以准确判断元素是否过期;小窗口(≤5)且数据量小时可用 list。

python 滑动窗口算法实现与性能分析

滑动窗口该用 list 还是 deque?

list 模拟滑动窗口在频繁 pop(0) 时会退化成 O(n) 时间复杂度,因为每次都要移动后续所有元素;而 collections.dequepopleft() 是 O(1)。除非窗口极小(比如固定长度 ≤ 5)且数据量不大,否则默认选 deque

实操建议:

  • 导入写成 from collections import deque,避免每次调用都带模块前缀
  • 初始化窗口用 win = deque(maxlen=k) 可自动丢弃左端,但注意它不支持随机索引访问,需额外变量存最大/最小值
  • 若需频繁查窗口内最值,直接用 deque 维护单调队列比反复调用 max(win) 高效得多

单调队列中存下标还是存值?

必须存下标。只存值无法判断某个元素是否已滑出窗口——因为重复值会导致无法区分“哪个 5 已过期”。下标能精确计算位置,配合当前右边界 r 判断 if q[0] 是否越界。

常见错误现象:

立即学习Python免费学习笔记(深入)”;

  • 窗口最大值突然变小,且不再恢复 → 很可能是用值做判断,把未过期的重复值误删了
  • 结果数组长度不对 → 下标没和循环变量对齐,比如用 for i, x in enumerate(nums) 但内部仍用 i+1 当右端点

典型写法片段:

q = deque()
for r in range(len(nums)):
while q and nums[q[-1]] <= nums[r]:
q.pop()
q.append(r)
if q[0] <= r - k:
q.popleft()
if r >= k - 1:
res.append(nums[q[0]])

matlab基础知识简介 中文WORD版
matlab基础知识简介 中文WORD版

MATLAB(矩阵实验室)是MATrix LABoratory的缩写,是一款由美国The MathWorks公司出品的商业数学软件。MATLAB是一种用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境。除了矩阵运算、绘制函数/数据图像等常用功能外,MATLAB还可以用来创建用户界面及与调用其它语言(包括C,C++和FORTRAN)编写的程序。MATLAB基础知识;命令窗口是用户与MATLAB进行交互作业的主要场所,用户输入的MATLAB交互命令均在命令窗口执行。 感兴趣的朋友可以

下载

固定长度 vs 可变长度滑动窗口怎么选模板?

固定长度(如「长度为 k 的子数组最大值」)适合用双指针 + 单调队列,逻辑集中在右指针推进、左边界自动校验;可变长度(如「和至少为 target 的最短子数组」)则必须显式维护 left 指针,并在内层 while 中收缩。

关键区别点:

  • 固定窗口:右指针每步必进,左指针不动或只动一次,for r in range(n) 足够
  • 可变窗口:左指针可能连走多步,必须用 while sum_val >= target: 循环收缩,且需在收缩后才更新答案
  • 性能影响:可变窗口最坏是 O(2n),看似两重循环,但每个元素最多进出窗口各一次,仍是线性

LeetCode 239 题本地调试总输出空列表?

大概率是忘了在 r >= k - 1 时才开始记录结果。比如 k=3,合法窗口从索引 2 开始(0-based),但循环从 r=0 开始,前两轮不能 append。

调试技巧:

  • 打印每轮的 rqnums[q[0]] 和是否 append,比只看最终结果更快定位漏填点
  • 用小样例手跑:nums = [1,3,-1,-3,5,3,6,7], k = 3,正确输出应为 [3,3,5,5,6,7],少一个就说明边界条件错
  • 注意题目是否要求返回「每个窗口的最大值」还是「所有窗口最大值中的最大值」——后者只需一个变量,不用数组

真正麻烦的是窗口内需同时维护多个统计量(比如最大值 + 最小值 + 出现次数),这时单个 deque 不够用,得拆成多个结构,或者改用平衡二叉树模拟(Python 里常用 sortedcontainers,但 OJ 通常不预装)。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

775

2023.08.22

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

344

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1073

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

176

2025.09.12

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

407

2023.08.14

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

109

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

16

2026.01.26

苹果官方查询网站 苹果手机正品激活查询入口
苹果官方查询网站 苹果手机正品激活查询入口

苹果官方查询网站主要通过 checkcoverage.apple.com/cn/zh/ 进行,可用于查询序列号(SN)对应的保修状态、激活日期及技术支持服务。此外,查找丢失设备请使用 iCloud.com/find,购买信息与物流可访问 Apple (中国大陆) 订单状态页面。

131

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号