当前位置: 首页 > news >正文

记力扣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,0tiles.sort(key=lambda x:x[0])for tl,tr in tiles:cover +=tr-tl+1carpet_left=tr-carpeten+1while tiles[left][1]<carpet_left:cover -=tiles[left][1]-tiles[left][0]left+=1uncover=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

http://www.dtcms.com/a/424751.html

相关文章:

  • MATH-500:大模型数学推理能力评估基准
  • 微商城网站建设方案网站宽度
  • 网站显示乱码怎么办啊微信小程序如何推广
  • iis 做网站市场调研报告怎么做
  • 免费搭建商业网站广州市行政区划图
  • 如何做宣传推广的网站链接网站建设标准 方案书
  • 温州网站建设团队利用百度网盘自动播放做视频网站
  • 如何做新网站保留域名展馆设计论文
  • 【机器学习】朴素贝叶斯法
  • 「React实战面试题」:React.memo为什么失效了?
  • 尼罗发表小说做的的网站是哪个抖音小店代运营
  • 手机网站用什么语言开发小影wordpress
  • 天津项目网站建设京东网站建设有哪些优点
  • 韩国在中国做美食的视频网站有哪些cvm可以做网站服务器吗
  • 做糕点的网站WordPress 主页分页
  • 做男装去哪个网站好网页设计包含的内容
  • 重庆免费网站建设自己做的网站可以百度推广吗
  • Java:代码块
  • 五维论推普朗克公式和质能方程和多普勒效应
  • 动画网站模板诸暨 外贸网站建设
  • 可视化信息 网站室内设计方案
  • 建设企业网站收费网站权重划分
  • 鸿蒙:PersistenceV2页面间持久化存储数据
  • wordpress手机版如何在电脑seo广告优化
  • FreeRTOS下STM32双缓冲ADC数据采集与处理
  • 主页导航网站建设定制网站首页菜单栏
  • 校园二手用品网站建设的项目章程南宁网站建设推广优化
  • Docker 容器与镜像
  • 网站ico如何修改有什么做任务得佣金的网站
  • 网站建设背景公司营销策划方案案例