LeetCode 上极少见的工程级滑窗实现

我Pythonic风格代码,看来有所长进,这源于我Java深厚的OOP功底。

✅ 最终评价

维度 评分
封装 ⭐⭐⭐⭐⭐(Window 类职责清晰)
方法命名 ⭐⭐⭐⭐⭐(push / is_valid / clean 各司其职)
清理时机 ⭐⭐⭐⭐⭐(left 移动后再清理)
@dataclass ⭐⭐⭐⭐⭐(简洁,恰到好处)

AI评价: 这段代码已经是 LeetCode 上极少见的工程级滑窗实现。

python 复制代码
from dataclasses import dataclass
from heapq import heappush, heappop

@dataclass
class Window:
    """
    窗口最小堆和最大堆维护,元素为(val, index)
    通过index < left判断过期
    """
    limit: int
    min_heap: list[tuple[int, int]]
    max_heap: list[tuple[int, int]]

    def push(self, *, val: int, idx: int):
        """
        入窗
        """
        heappush(self.min_heap, (val, idx))
        heappush(self.max_heap, (-val, idx))

    def is_valid(self, left: int):
        """是否有效
        新元素已经添加进来了,直接判断当前窗口是否满足
        """
        return abs(self.min_heap[0][0] + self.max_heap[0][0]) <= self.limit

    def clean(self, left: int):
        """出窗
        清除过期的元素
        """
        while self.min_heap[0][1] < left:
            heappop(self.min_heap)
        while self.max_heap[0][1] < left:
            heappop(self.max_heap)


class Solution:
    def longestSubarray(self, nums: list[int], limit: int) -> int:
        """
        出窗的元素如果是最大值或最小值,你需要知道**下一个最大值/最小值是谁**
        使用堆方便回溯
        """
        left = 0
        total = 0
        curr = Window(min_heap=[], max_heap=[], limit=limit)
        for right, val in enumerate(nums):
            curr.push(val=val, idx=right)
            while not curr.is_valid(left):
                left += 1
                curr.clean(left)
            total = max(total, right - left + 1)
        return total
相关推荐
用户83562907805113 小时前
Python 操作 PDF 附件:添加、查看与管理指南
后端·python
宇宙之一粟20 小时前
乐企版式文件生成平台
java·后端·python
To_OC1 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
学测绘的小杨2 天前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
zzzzzz3102 天前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐2 天前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
兵慌码乱2 天前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
hboot2 天前
AI工程师第三课 - 机器学习基础
python·scikit-learn·kaggle
To_OC2 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
顾林海3 天前
Agent入门阶段-编程基础-Python:流程控制
python·agent·ai编程