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

一个方法解决三道区间问题

1288. 删除被覆盖区间
56. 合并区间
986. 区间列表的交集

# 1288. 删除被覆盖区间
class Solution:def removeCoveredIntervals(self, intervals: List[List[int]]) -> int:# 按照起点升序排列,起点相同时,按照终点降序排列intervals.sort(key = lambda x: (x[0], -x[1]))# 记录被覆盖区间的个数res = 0# 记录合并区间的起点和终点left, right = intervals[0][0], intervals[0][1]i = 1while i < len(intervals):curr = intervals[i]# 覆盖if left <= curr[0] and curr[1] <= right:res += 1# 合并if curr[0] <= right <= curr[1]:right = curr[1]# 无交集,更新left rightif right <= curr[0]:left, right = curr[0], curr[1]i += 1return len(intervals) - res
# 56. 合并区间
class Solution:def merge(self, intervals: List[List[int]]) -> List[List[int]]:intervals.sort()res = [intervals[0]]i = 1while i < len(intervals):last = res[-1]curr = intervals[i]if curr[0] <= last[1]:last[1] = max(last[1], curr[1])else:res.append(curr)i += 1return res
# 986. 区间列表的交集
class Solution:def intervalIntersection(self, firstList: List[List[int]], secondList: List[List[int]]) -> List[List[int]]:i, j = 0, 0res = []while i < len(firstList) and j < len(secondList):a1, a2 = firstList[i][0], firstList[i][1]b1, b2 = secondList[j][0], secondList[j][1]if b2>=a1 and b1<=a2:c1, c2 = max(a1, b1), min(a2, b2)res.append([c1, c2])if a2 < b2:i += 1else:j += 1return res
http://www.lryc.cn/news/177686.html

相关文章:

  • sub0 里斯本精彩回顾:探索波卡区块的创新空间
  • 颜色+情感的英语表达还有这些,零基础学英语口语去哪里,柯桥有推荐的吗?
  • exoplayer的使用-6,播放器的选择
  • Windows上安装 Go 环境
  • 【设计模式】四、工厂模式
  • 十九,镜面IBL--BRDF积分贴图
  • Linux 创建 终止线程(thread)
  • 【IPC 通信】信号处理接口 Signal API(6)
  • ipaguard界面概览
  • 萌新的FPGA学习绪论-1
  • 目标检测算法改进系列之Backbone替换为EMO
  • Laravel一些优雅的写法
  • vue+three.js中使用Ammo.js
  • 【k8s】kubectl命令详解
  • Centos 7 部署SVN服务器
  • SEO方案尝试--Nuxtjs项目基础配置
  • 【算法分析与设计】动态规划(上)
  • Java多线程篇(6)——AQS之ReentrantLock
  • 【计算机网络】IP协议第二讲(Mac帧、IP地址、碰撞检测、ARP协议介绍)
  • TouchGFX界面开发 | 按钮控件应用示例
  • BSVD论文理解:Real-time Streaming Video Denoising with Bidirectional Buffers
  • 共同见证丨酷雷曼武汉运营中心成立2周年
  • 一种单键开关机电路图
  • 设计模式2、抽象工厂模式 Abstract Factory
  • C++ 32盏灯,利用进制和 与 或 进行设计
  • Ffmpeg-(1)-安装:ubuntu系统安装Ffmpeg应用
  • 系统集成|第十一章(笔记)
  • 二叉树题目:二叉树剪枝
  • JAVA中使用CompletableFuture进行异步编程
  • uniapp:配置动态接口域名,根据图片访问速度,选择最快的接口