【代码随想录】【贪心算法】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
相关推荐
m0_686041614 分钟前
C++中的适配器模式变体
开发语言·c++·算法
txzrxz4 分钟前
结构体排序,双指针,单调栈
数据结构·算法·双指针算法·单调栈·结构体排序
AndrewHZ8 分钟前
【AI黑话日日新】什么是AI智能体?
人工智能·算法·语言模型·大模型·llm·ai智能体
wWYy.9 分钟前
算法:二叉树最大路径和
数据结构·算法
葱明撅腚11 分钟前
利用Python挖掘城市数据
python·算法·gis·聚类
We་ct14 分钟前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
weixin_3954489125 分钟前
main.c_cursor_0129
前端·网络·算法
CS创新实验室38 分钟前
《计算机网络》深入学:路由算法与路径选择
网络·计算机网络·算法
一条大祥脚38 分钟前
ABC357 基环树dp|懒标记线段树
数据结构·算法·图论
tod11338 分钟前
力扣高频 SQL 50 题阶段总结(四)
开发语言·数据库·sql·算法·leetcode