当前位置: 首页> 娱乐> 八卦 > 每日军事新闻下载安装_seo发布专员招聘_站长之家站长工具_合肥seo整站优化网站

每日军事新闻下载安装_seo发布专员招聘_站长之家站长工具_合肥seo整站优化网站

时间:2025/7/11 14:09:27来源:https://blog.csdn.net/weixin_56989647/article/details/143178833 浏览次数:2次
每日军事新闻下载安装_seo发布专员招聘_站长之家站长工具_合肥seo整站优化网站

56. 合并区间 - 力扣(LeetCode)

思路:

先按照左边界从大到小对数组进行排序;

遍历数组:如果当前遍历的区间左边界小于等于前一个区间的右边界,更新当前区间的左边界为最小的左边界,右边界为最大的右边界;如果没有重叠,就将前一个区间加入res中。

问题:最后一个区间没法加入res中,所以我在数组最后添加了一个元素[100000,100000]。

class Solution(object):def merge(self, intervals):intervals.sort(key=lambda x:(x[0],x[1]))intervals.append([100000,100000])res=[]for i in range(1,len(intervals)):if intervals[i][0]<=intervals[i-1][1]:intervals[i][0]=min(intervals[i-1][0],intervals[i][0])intervals[i][1]=max(intervals[i-1][1],intervals[i][1])else:res.append(intervals[i-1])return res

题解思路:

将排序后的第一个元素直接加入res中;

遍历数组:如果当前元素的左边界小于等于res中的最后一个元素的右边界,说明重叠,则更新res的最后一个元素的右边界为最大的右边界;否则直接将当前元素加入res中。

class Solution(object):def merge(self, intervals):intervals.sort(key=lambda x:(x[0],x[1]))res=[intervals[0]]for i in range(1,len(intervals)):if intervals[i][0]<=res[-1][1]:res[-1][1]=max(intervals[i][1],res[-1][1])else:res.append(intervals[i])return res

关键字:每日军事新闻下载安装_seo发布专员招聘_站长之家站长工具_合肥seo整站优化网站

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: