记力扣2271.毯子覆盖的最多白色砖块数 练习理解

给你一个二维整数数组 tiles ,其中 tiles[i] = [li, ri] ,表示所有在 li <= j <= ri 之间的每个瓷砖位置 j 都被涂成了白色。

同时给你一个整数 carpetLen ,表示可以放在 任何位置 的一块毯子的长度。

请你返回使用这块毯子,最多 可以盖住多少块瓷砖。

思路:

先将列表按元素第一个数字大小顺序排序(tiles.sort(key:lambda x:x[0]),接着开始遍历,算出每一个列表的长度,然后通过carpet_left=该列表右端点长减去毯子长 +1 算 出毯子左端点的位置,然后去判断第一个列表的右端点是否小于毯子左端点如果成立则需要剔除该列表的长度,达到合适的有效毯子覆盖,然后算出不被覆盖的最大长度,然后结果就是max(ans,cover-uncover),前面算的是完全不在范围内的列表长度,最后还需把部分重叠的减去才是最终的结果

复制代码
from typing import List
class Solution:
    def maximumWhiteTiles(self,tiles:List[int],carpeten:int)->int:
        ans,cover,left=0,0,0
        tiles.sort(key=lambda x:x[0])
        for tl,tr in tiles:
            cover +=tr-tl+1
            carpet_left=tr-carpeten+1
            while tiles[left][1]<carpet_left:
                cover -=tiles[left][1]-tiles[left][0]
                left+=1
            uncover=max(carpet_left-tiles[left][0],0)
            ans=max(ans,cover-uncover)
        return ans

难点:

  1. 区间覆盖的边界处理

    • 难点在于计算uncover部分:max(carpet_left - tiles[left][0], 0)
    • 这部分需要准确判断当前左边界瓷砖有多少部分不在被地毯覆盖,尤其是当地毯左边界落在某个瓷砖区间中间时
  2. 滑动窗口的调整策略

    • 如何确定窗口左边界的移动时机:while tiles[left][1] < carpet_left
    • 需要精准判断哪些瓷砖完全不在被当前地毯覆盖,从而从窗口中移除
  3. 地毯长度与瓷砖区间的匹配

    • 当地毯长度大于多个瓷砖区间总和时的处理
    • 当地毯长度小于单个瓷砖区间时的部分覆盖计算
  4. 最优解的更新时机

    • 每次调整窗口后都需要计算当前有效覆盖长度,并与历史最优解比较
    • 这里的有效覆盖长度是cover - uncover,而不是简单的cover
相关推荐
CQ_YM2 分钟前
数据结构之双向链表
数据结构·链表
一只乔哇噻3 分钟前
java后端工程师+AI大模型进修ing(研一版‖day59)
java·开发语言·算法·语言模型
天赐学c语言3 分钟前
12.2 - LRU缓存 && C语言内存布局
c++·算法·lru·内存布局
不羁的木木4 分钟前
【开源鸿蒙跨平台开发学习笔记】Day07:React Native 开发 HarmonyOS-GitCode口袋工具开发-3
学习·开源·harmonyos
yoyo君~4 分钟前
深入理解PX4飞控系统:多线程并发、原子操作与单例模式完全指南
学习·单例模式·机器人·无人机
山土成旧客5 分钟前
【Python学习打卡-Day17】从二分类到多分类:ROC曲线、三大平均指标与风控利器MCC/KS
python·学习·分类
love530love7 分钟前
【SD WebUI踩坑】启动报错 Expecting value: line 1 column 1 (char 0) 的终极解决方案
人工智能·windows·python·github·stablediffusion
曲幽8 分钟前
Flask入门实战:轻松掌握模板渲染与静态文件加载
css·python·html·web·js·image·templates·assets
暗然而日章10 分钟前
C++基础:Stanford CS106L学习笔记 5 内存与指针
c++·笔记·学习