LeetCode-56-Merge Intervals Python自定义sort,贪心

本文介绍了一种用于合并多个区间的高效算法。通过定义区间类并实现比较方法,该算法能够将一系列不重叠的区间按顺序合并成最小数量的区间集合。文章详细解释了算法的实现过程,并提供了完整的Python代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


# Definition for an interval.
# class Interval(object):
#     def __init__(self, s=0, e=0):
#         self.start = s
#         self.end = e

class Solution(object):
    
    def comp(self, a, b):
        if a.start>b.start:return 1
        elif a.start==b.start:return 0
        else : return -1
    
    def merge(self, intervals):
        """
        :type intervals: List[Interval]
        :rtype: List[Interval]
        """
        Len=len(intervals)
        if Len<=1:return intervals
        intervals.sort(self.comp)
        ans=[]
        cur=intervals[0]
        for i in range(1,Len):
            if intervals[i].start>cur.end:
                ans.append(cur)
                cur=intervals[i]
            else:
                cur=Interval(cur.start,max(intervals[i].end,cur.end))
            if i+1==Len:ans.append(cur)
        
        
        return ans


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值