尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

第56 合并区间 - 指南

第56 合并区间 - 指南
📅 发布时间:2026/6/20 17:34:58

题目

以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。

示例 1:

输入:intervals = [[1,3],[2,6],[8,10],[15,18]]
输出:[[1,6],[8,10],[15,18]]
解释:区间 [1,3] 和 [2,6] 重叠, 将它们合并为 [1,6].

示例 2:

输入:intervals = [[1,4],[4,5]]
输出:[[1,5]]
解释:区间 [1,4] 和 [4,5] 可被视为重叠区间。

示例 3:

输入:intervals = [[4,7],[1,4]]
输出:[[1,7]]
解释:区间 [1,4] 和 [4,7] 可被视为重叠区间。

提示:

  • 1 <= intervals.length <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 104

思路

先需要按照左区间进行排序,选取一个数据结构,可以对相邻区间进行合并

这里我认为栈可以对相邻区间进行弹出插入,使用起来比较方便,可以快速弹出插入对区间进行合并

具体思路如下
先按照左区间进行排序,然后把第一个区间插入到栈中
从栈中弹出区间和当前需要插入的区间进行合并
以弹出区间的右区间为基准,分为三种情况
弹出区间的右区间 > 当前区间的右区间         
        直接取弹出区间
弹出区间的右区间 >= 当前区间的左区间         
        左区间取弹出区间的左区间、右区间取当前区间的右区间
否则只有一种情况,弹出区间的右区间 < 当前区间的左区间
        需要把两个区间都插入到栈中
最后栈转化为集合返回结果

代码示例

import java.util.*;
public class lc56 {public static void main(String[] args) {//二维数组编写输入就比较复杂了//考虑到面试要快速验证结果,建议直接把输入结果写在代码中int[][] arr = {{1,4},{4,5}};lc56 lc56 = new lc56();int[][] merge = lc56.merge(arr);for (int i = 0; i < merge.length; i++) {for (int j = 0; j < merge[i].length; j++) {System.out.print(merge[i][j] + " ");}System.out.println();}}public int[][] merge(int[][] intervals) {//先按照左区间进行排序Arrays.sort(intervals,new Comparator() {public int compare(int[] o1, int[] o2) {return o1[0]-o2[0];}});//然后把第一个区间插入到栈中Stack stack = new Stack<>();stack.push(intervals[0]);//从栈中弹出区间和当前需要插入的区间进行合并for (int i = 1; i < intervals.length; i++) {//以弹出区间的右区间为基准,分为三种情况int[] pop1 = stack.pop();//弹出区间的右区间 > 当前区间的右区间//直接取弹出区间if(pop1[1] > intervals[i][1]){stack.push(pop1);//弹出区间的右区间 >= 当前区间的左区间// 左区间取弹出区间的左区间、右区间取当前区间的右区间}else if(pop1[1] >= intervals[i][0]){pop1[1] = intervals[i][1];stack.push(pop1);//否则只有一种情况,弹出区间的右区间 < 当前区间的左区间//需要把两个区间都插入到栈中}else{stack.push(pop1);stack.push(intervals[i]);}}//最后栈转化为集合返回结果return stack.toArray(new int[stack.size()][]);}
}

相关新闻

  • 详细介绍:uniapp设置vuex公共值状态管理
  • 2025年热门的上海旋转蒸发器最新TOP厂家排名
  • 2025杭州全域外卖服务商TOP5深度测评:斯创全域外卖与其

最新新闻

  • 2026 年 6 月欧米茄中国区维保网点调整 全新服务专线发布 - 欧米茄中国服务中心
  • WarcraftHelper魔兽争霸插件完整教程:让经典游戏完美适配现代电脑的终极解决方案
  • 重磅更新|2026年6月欧米茄官方售后网点实地核验完整官方报告,全新正规维修网点全新地址启用 - 欧米茄中国服务中心
  • 本地标杆|2026年西宁旅游公司怎么选?本地深耕 vs 全国连锁,靠谱公司真实体验告诉你答案 - 资讯速览
  • 北京购宠优选!鸿雨犬舍两大实体门店,选纯种狗狗省心不踩坑 - 北京同城宠物基地
  • 嵌入式GUI窗口管理器:消息驱动、内存设备与定时器实战解析

日新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号