题解 | #合并区间#

合并区间

http://www.nowcoder.com/practice/69f4e5b7ad284a478777cb2a17fb5e6a

没有奇技淫巧,先对start排序,再逐个比较

# class Interval:
#     def __init__(self, a=0, b=0):
#         self.start = a
#         self.end = b

#
# 
# @param intervals Interval类一维数组 
# @return Interval类一维数组
#
class Solution:
    def merge(self , intervals ):
        if len(intervals) <= 1:
            return intervals      
        # write code here              
        intervals.sort(key = lambda x:x.start)


        n = len(intervals)
        res = []
        curr = intervals[0]

        for i in range(1, n):
            temp = intervals[i]           
            if temp.start > curr.end: # not overlap
                res.append(Interval(a=curr.start, b=curr.end))                               
                curr = temp
            elif curr.end < temp.end: # overlap and merge
                curr.end = temp.end
            if i == n-1:
                res.append(Interval(a=curr.start, b=curr.end))       
        return res


            #update curr

全部评论

相关推荐

2025-12-29 20:37
已编辑
清华大学附属小学 Java
开始打牌offer啦:1.为什么要写这么多内容呀 2.什么叫做简历 3.什么样的内容可以写到简历上 4.项目可以包装,但是要有理有据呀,不能乱包装呀,比如 跨境能达到日均120万订单的在国内都是能叫的上名字的,而且这些工作也基本上不太会交给一个实习生去做 建议友友可以去网上或者找同学的简历看看,他们的简历是怎么写的,去找找上面的那四个问题的答案吧,然后要记住的是Java是服务于业务的,而不是服务于微服务或者技术的
最后再改一次简历
点赞 评论 收藏
分享
02-04 12:01
九江学院 C++
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务