【代码随想录】【贪心算法】day36:无重叠子区间,划分字母区间,合并区间

python 复制代码
class Solution(object):
    def eraseOverlapIntervals(self, intervals):
        """
        :type intervals: List[List[int]]
        :rtype: int
        """

        intervals.sort(key=lambda x:x[0])
        count=0

        # 可以记录重叠子区间的个数,然后让整个数组的长度减去重叠的个数
        # 需要去维护右边界是最小的那个,左边界是最大的那个
        #left=intervals[0][0]
        right=intervals[0][1]

        for i in range(1,len(intervals)):
            # 如果没有重叠
            if intervals[i][0] >= right:
                right=intervals[i][1]
                # left=intervals[i][0]

            else:
                count+=1
                right=min(right,intervals[i][1])

        return count

划分

python 复制代码
class Solution(object):
    def partitionLabels(self, s):
        """
        :type s: str
        :rtype: List[int]
        """
        # 不能排序
        # 统计每个字符最后出现的位置

        # 循环,如果遍历的当前字母的位置和最后出现的位置相同,则找到一个分割点
        last={}
        max_last=0
        result=[]
        start=0
        for i in range(len(s)):
            last[s[i]]=i

        for i in range(len(s)):
            max_last=max(max_last,last[s[i]])
            if i==max_last:

                result.append(max_last-start+1)
                start=i+1
        return result

合并区间

记得排序,记得和result[-1][1]作比较

python 复制代码
class Solution(object):
    def merge(self, intervals):
        """
        :type intervals: List[List[int]]
        :rtype: List[List[int]]
        """
    # 如果下一个的left  小于上一个的right 那就是合并
    # 一定要进行更新
   
        intervals.sort(key=lambda x:x[0])

        result=[]
        result.append(intervals[0])
        

        for i in range(1,len(intervals)):
            # 如果不重叠
            if intervals[i][0] > result[-1][1]:
                result.append(intervals[i])
                
            else:
                result[-1][1]=max(result[-1][1],intervals[i][1])
                
        return  result
相关推荐
轻抚酸~6 小时前
KNN(K近邻算法)-python实现
python·算法·近邻算法
Yue丶越8 小时前
【C语言】字符函数和字符串函数
c语言·开发语言·算法
小白程序员成长日记9 小时前
2025.11.24 力扣每日一题
算法·leetcode·职场和发展
有一个好名字9 小时前
LeetCode跳跃游戏:思路与题解全解析
算法·leetcode·游戏
AndrewHZ10 小时前
【图像处理基石】如何在图像中提取出基本形状,比如圆形,椭圆,方形等等?
图像处理·python·算法·计算机视觉·cv·形状提取
蓝牙先生10 小时前
简易TCP C/S通信
c语言·tcp/ip·算法
稚辉君.MCA_P8_Java13 小时前
Gemini永久会员 Java中的四边形不等式优化
java·后端·算法
稚辉君.MCA_P8_Java14 小时前
通义 插入排序(Insertion Sort)
数据结构·后端·算法·架构·排序算法
无限进步_14 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
Swift社区14 小时前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode