【Day26】LeetCode:452. 用最少数量的箭引爆气球,435. 无重叠区间,763. 划分字母区间

文章目录

  • [LeetCode:452. 用最少数量的箭引爆气球](#LeetCode:452. 用最少数量的箭引爆气球)
  • [LeetCode:435. 无重叠区间](#LeetCode:435. 无重叠区间)
  • [LeetCode:763. 划分字母区间](#LeetCode:763. 划分字母区间)

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

https://leetcode.cn/problems/minimum-number-of-arrows-to-burst-balloons/description/

思路

  1. 将所有区间按照 xend 从小到大排列。
  2. 第一支箭射在第一个区间的右端点。
  3. 遍历后续区间:
    (1)如果当前区间的左端点 xstart 大于上一支箭的位置,说明这支箭无法射中当前气球,必须发射一支新箭,并将新箭的位置设为当前区间的右端点。
    (2)否则,当前区间可以被上一支箭覆盖,无需新箭。

解答

python 复制代码
class Solution:
    def findMinArrowShots(self, points: List[List[int]]) -> int:
        points.sort(key=lambda x: x[1]) # 按区间右端点升序排序
        
        arrows = 1
        current_end = points[0][1]  # 第一支箭的位置
        
        for xstart, xend in points[1:]:
            if xstart > current_end: # 如果当前气球左端点 > 上一支箭的位置,需要新箭
                arrows += 1
                current_end = xend
        
        return arrows

LeetCode:435. 无重叠区间

https://leetcode.cn/problems/non-overlapping-intervals/

思路

贪心时选择最早结束的区间,可以最大化剩余空间,使得后续有更多区间可能被容纳。

解答

python 复制代码
class Solution:
    def eraseOverlapIntervals(self, intervals: List[List[int]]) -> int:
        intervals.sort(key=lambda x: x[1]) # 按区间右端点升序排序
        
        last_end = intervals[0][1]
        remain = 1 # 至少保留一个

        for start, end in intervals[1:]:
            if start >= last_end: # 不重叠,保留
                remain += 1
                last_end = end
        
        return len(intervals) - remain

LeetCode:763. 划分字母区间

https://leetcode.cn/problems/partition-labels/

思路

  1. 第一次遍历:记录每个字符在字符串中最后出现的索引。
  2. 第二次遍历:
    (1)初始化 start = 0end = 0
    (2)遍历每个字符 s[i],更新 end = max(end, last_index[s[i]]),表示当前片段必须延伸到当前字符的最后出现位置。
    (3)当 i == end 时,说明从 startend 的片段已经包含了所有出现的字符,且不会与后面的片段冲突,因此可以切分。记录长度 end - start + 1,然后将 start 更新为 i + 1

解答

python 复制代码
class Solution:
    def partitionLabels(self, s: str) -> List[int]:
        # 统计每一个字符最后出现的位置
        last_index = {}
        n = len(s)
        for i in range(n):
            last_index[s[i]] = i
        
        results = []
        start = 0
        end = 0
        for i in range(n):
            end = max(end, last_index[s[i]])
            if i == end:
                results.append(end - start + 1)
                start = i + 1
        return results
相关推荐
Ulyanov1 分钟前
音视频分离与音频处理核心技术深度解析 从MP4到高品质音乐文件的完整技术实现
python·音视频
萝卜白菜。7 分钟前
TongWeb8.0 JNDI缓存
开发语言·python·缓存
xiaoshuaishuai89 分钟前
PyCharm性能调优
ide·python·pycharm
AI成长日志25 分钟前
【笔面试算法学习专栏】堆与优先队列实战:力扣hot100之215.数组中的第K个最大元素、347.前K个高频元素
学习·算法·leetcode
6Hzlia25 分钟前
【Hot 100 刷题计划】 LeetCode 45. 跳跃游戏 II | C++ 贪心算法最优解题解
c++·leetcode·游戏
北顾笙98029 分钟前
day18-数据结构力扣
数据结构·算法·leetcode
&&Citrus35 分钟前
【CPN 学习笔记(三)】—— Chap3 CPN ML 编程语言 上半部分 3.1 ~ 3.3
笔记·python·学习·cpn·petri网
阿Y加油吧37 分钟前
LeetCode 中等难度 | 回溯法进阶题解:单词搜索 & 分割回文串
算法·leetcode·职场和发展
Dream of maid38 分钟前
Python(11) 进程与线程
开发语言·python
财经资讯数据_灵砚智能1 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年4月7日
大数据·人工智能·python·信息可视化·语言模型·自然语言处理·ai编程