leetcoede56. 合并区间

98 篇文章 1 订阅
83 篇文章 1 订阅

在这里插入图片描述

思路

先根据每个区间的第2个值排序,然后从后往前,如果i区间的左小于等于i-1区间的右,则合并到i-1位置,并删除原来i位置的区间,依此类推。

代码

class Solution:
    def merge(self, intervals: List[List[int]]) -> List[List[int]]:
        intervals = sorted(intervals,key=lambda x:x[1])
        for i in range(len(intervals)-1,0,-1):
            if intervals[i][0]<=intervals[i-1][1]:
                #重写i-1区间的左和右
       		    intervals[i-1][1] =max(intervals[i][1],intervals[i-1][1])
       		    intervals[i-1][0] =min(intervals[i][0],intervals[i-1][0])    		
       		    intervals.pop(i)    #删除i区间
        return intervals
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值