【代码随想录】【贪心算法】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
相关推荐
hsling松子4 小时前
使用PaddleHub智能生成,献上浓情国庆福
人工智能·算法·机器学习·语言模型·paddlepaddle
dengqingrui1235 小时前
【树形DP】AT_dp_p Independent Set 题解
c++·学习·算法·深度优先·图论·dp
C++忠实粉丝5 小时前
前缀和(8)_矩阵区域和
数据结构·c++·线性代数·算法·矩阵
ZZZ_O^O5 小时前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
CV-King6 小时前
opencv实战项目(三十):使用傅里叶变换进行图像边缘检测
人工智能·opencv·算法·计算机视觉
代码雕刻家6 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
雨中rain6 小时前
算法 | 位运算(哈希思想)
算法
Kalika0-08 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
sp_fyf_20248 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-02
人工智能·神经网络·算法·计算机视觉·语言模型·自然语言处理·数据挖掘
我是哈哈hh10 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝