【代码随想录】【贪心算法】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
相关推荐
焦糖码奇朵、5 分钟前
Matlab:矩阵运算篇——矩阵
算法·matlab·矩阵·信息与通信
ZRD111231 分钟前
Swift flatMap 和 compactMap
ios·swift
I_Am_Me_42 分钟前
【贪心算法】柠檬水找零
算法·贪心算法
Joyner20181 小时前
python-leetcode-递增的三元子序列
算法·leetcode·职场和发展
GeekPMAlex1 小时前
Python 系列01 Python里面self的用法
算法
仟濹2 小时前
【前缀和与差分 二分搜索 C/C++】洛谷 P1083 借教室
c语言·c++·算法
xinxiangwangzhi_2 小时前
多视图几何--从线性变换到射影变换--2线性变换
人工智能·算法·计算机视觉
AI技术控2 小时前
计算机视觉算法实战——昆虫识别检测(主页有源码)
人工智能·算法·计算机视觉
西猫雷婶3 小时前
python学智能算法(七)|KNN邻近算法
算法