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

✅DAY30 贪心算法 | 452. 用最少数量的箭引爆气球 | 435. 无重叠区间 | 763.划分字母区间

452. 用最少数量的箭引爆气球

解题思路:首先把原数组按左边界进行排序。然后比较[i-1]的右边界和[i]的左边界是否重叠,如果重叠,更新当前右边界为最小右边界和[i+1]的左边界判断是重叠。

class Solution:def findMinArrowShots(self, points: List[List[int]]) -> int:if len(points) == 0: return 0points.sort(key=lambda x: x[0])result = 1for i in range(1, len(points)):if points[i][0] > points[i-1][1]: # 第二段的头和第一段的尾不衔接result += 1else:points[i][1] = min(points[i-1][1], points[i][1]) # else是这两段重叠,但是要判断下一个部分是否重叠# 更新尾为最小的右边界,如果下一个[i][0]< [i-1][1],则又有一段重叠return result

优化:按右边界排序的方式通常更直观,因为只需要维护一个变量 current_end 表示当前的射击位置,不需要更新区间边界,也减少了不必要的操作。

class Solution:def findMinArrowShots(self, points: List[List[int]]) -> int:if not points: return 0points.sort(key=lambda x: x[1])  # 按右边界排序result = 1current_end = points[0][1]for i in range(1, len(points)):if points[i][0] > current_end:result += 1current_end = points[i][1]return result

435. 无重叠区间

class Solution:def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:if not intervals: return 0intervals.sort(key = lambda x:x[0])count = 0for i in range(1, len(intervals)):if intervals[i-1][1] > intervals[i][0]: # 存在重叠intervals[i][1] = min(intervals[i-1][1], intervals[i][1])count += 1return count

763. 划分字母区间

class Solution:def partitionLabels(self, s: str) -> List[int]:last_occ = {}result = []for i, char in enumerate(s):last_occ[char] = istart_index, end_index = 0, 0for i, char in enumerate(s):end_index = max(end_index, last_occ[char])#找出当前字符出现的最远位置if i == end_index:#i遍历到当前end的最尾部,说明前面的所有出现字符到这停下了result.append(end_index - start_index + 1)start_index = i + 1return result
http://www.lryc.cn/news/488344.html

相关文章:

  • 关于Redis单线程模型以及IO多路复用的理解
  • 学习ASP.NET Core的身份认证(基于Cookie的身份认证1)
  • 奇门遁甲中看债务时用神该怎么取?
  • Redis 集群主要有以下几种类型
  • 使用 Axios 拦截器优化 HTTP 请求与响应的实践
  • mini-lsm通关笔记Week2Day5
  • mybatis的动态sql用法之排序
  • OneToMany 和 ManyToOne
  • 《生成式 AI》课程 第3講 CODE TASK 任务3:自定义任务的机器人
  • 反转链表、链表内指定区间反转
  • Debezium系列之:Debezium3版本使用快照过程中的指标
  • 第一讲,Opencv计算机视觉基础之计算机视觉概述
  • 数据结构(双向链表——c语言实现)
  • 【新人系列】Python 入门(十一):控制结构
  • 群核科技首次公开“双核技术引擎”,发布多模态CAD大模型
  • 【AI大模型引领变革】探索AI如何重塑软件开发流程与未来趋势
  • linux 常用命令指南(存储分区、存储挂载、docker迁移)
  • 用pyspark把kafka主题数据经过etl导入另一个主题中的有关报错
  • Redis的过期删除策略和内存淘汰机制以及如何保证双写的一致性
  • 异常处理:import cv2时候报错No module named ‘numpy.core.multiarray‘
  • C++手写PCD文件
  • 优选算法(双指针)
  • 【保姆级】Mac上IDEA卡顿优化
  • python实战案例----使用 PyQt5 构建简单的 HTTP 接口测试工具
  • pytest 接口串联场景
  • Springboot项目搭建(2)-用户详细信息查询
  • Stable Diffusion的加噪和去噪详解
  • 解决 Gradle 报错:`Plugin with id ‘maven‘ not found` 在 SDK 开发中的问题
  • EMD-KPCA-Transformer多变量回归预测!分解+降维+预测!多重创新!直接写核心!
  • 前端 px、rpx、em、rem、vh、vw计量单位的区别