LeetCode 56. 合并区间

以数组 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] 可被视为重叠区间。

提示:

  • 1 <= intervals.length <= 10^4
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 10^4

思路:

将 intervals 数组按照左边界 starti 升序排列。设置排序后 第0个区间的 左边界为 start,第0个区间的右边界为 end。从左向右比较(从 i =1 开始),如果当前区间的左边界小于或等于 end,则说明当前区间和 end 所代表的区间重合,此时应该更新 end 为已重合的区间的最大右边界值。若当前区间的 左边界大于 end,则说明当前区间和 前面已重合的区间并不重合,此时应该将之前已经重合的区间 [ start,end ] 添加进 结果列表 list 中,然后更新 start 为当前区间的左边界,更新 end 为当前区间的右边界,然后继续判断。

重点在于每次比较时要比较 当前区间的左边界和 已重合区间的最大右边界值,若当前区间的左边界小于已重合区间的最大右边界值,则更新已重合区间的最大右边界值;反之,则将已重合区间添加进结果列表中,并将当前区间的左边界和右边界设置为新的已重合区间的左边界和右边界。

代码:

class Solution {public int[][] merge(int[][] intervals) {//按照 start 升序排列Arrays.sort(intervals,(o1,o2)->{return Integer.compare(o1[0],o2[0]);});List<int[]> list = new LinkedList<>();int start = intervals[0][0];int end = intervals[0][1];for(int i=1;i<intervals.length;i++){if(intervals[i][0]<=end){//说明 intervals[i] 与之前的区间有重合//更新重合的区间的最大边界end = Math.max(end,intervals[i][1]);}else{//将已经重合的区间合并list.add(new int[]{start,end});//更新 start 和 end 的值start = intervals[i][0];end = intervals[i][1];}}list.add(new int[]{start,end});return list.toArray(new int[list.size()][]);}
}

参考:代码随想录

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/786746.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS 应用开发之LifecycleService接口切换LifecycleData接口切换

LifecycleService接口切换 FA模型接口Stage模型接口对应d.ts文件Stage模型对应接口onStart?(): void;ohos.app.ability.ServiceExtensionAbility.d.tsonCreate(want: Want): void;onCommand?(want: Want, startId: number): void;ohos.app.ability.ServiceExtensionAbility.…

算法训练营第27天|LeetCode 39.组合总和 40.组合总和2 131.分割回文串

LeetCode 39.组合总和 题目链接&#xff1a; LeetCode 39.组合总和 解题思路&#xff1a; 用回溯的方法&#xff0c;&#xff0c;注意这次回溯不是i1&#xff0c;而是i&#xff0c;是因为可用重复选取。 代码&#xff1a; class Solution { public:vector<vector<i…

nginx怎么配置https访问

一、安装nginx yum -y install nginx二、准备证书 申请证书&#xff0c;并将证书上传到/etc/pki/nginx/目录&#xff0c;证书可以在腾讯云等云平台申请 二、配置nginx user root; worker_processes auto;events {worker_connections 1024; }http {include mime.t…

关于ffmpeg的安装和编码格式问题

安装 5.1安装 https://blog.csdn.net/JineD/article/details/113528285 3.4.8安装 https://blog.csdn.net/qq_42528520/article/details/120487457 编码格式 ffmpeg能转很多的视频格式&#xff0c;不同的格式对应的版本也不一样。如上述安装5.1和3.4.8都是一样的流程&#xff0…

mysql故障及解决分析

目录 MySQL 单实例故障排查 MySQL 单实例故障排查 &#xff08;1&#xff09;故障现象 1 ERROR 2002 (HY000): Cant connect to local MySQL server through socket /data/mysql/mysql.sock (2) 问题分析&#xff1a;以上这种情况一般都是数据…

c# 插值搜索-迭代与递归(Interpolation Search)

给定一个由 n 个均匀分布值 arr[] 组成的排序数组&#xff0c;编写一个函数来搜索数组中的特定元素 x。 线性搜索需要 O(n) 时间找到元素&#xff0c;跳转搜索需要 O(? n) 时间&#xff0c;二分搜索需要 O(log n) 时间。 插值搜索是对实例二分搜索的改进&#xff0c;…

LeetCode 2810.故障键盘:双端队列模拟

【LetMeFly】2810.故障键盘&#xff1a;双端队列模拟 力扣题目链接&#xff1a;https://leetcode.cn/problems/faulty-keyboard/ 你的笔记本键盘存在故障&#xff0c;每当你在上面输入字符 i 时&#xff0c;它会反转你所写的字符串。而输入其他字符则可以正常工作。 给你一个…

前端 - 基础 表单标签 - 表单元素 input - (name Value checked maxlength )属性详解

目录 name 属性 Value 属性 Checked 属性 Maxlength 属性 场景问答 # <input> 标签 除了 type 属性外&#xff0c;还有其他常用属性 >>> name 属性 在上一节 我们遇到的 单选按钮 &#xff0c;为什么 本应该 多选一 结果成了 多选多的问题 就…

# 达梦数据库知识点

达梦数据库知识点 测试数据 -- SYSDBA.TABLE_CLASS_TEST definitionCREATE TABLE SYSDBA.TABLE_CLASS_TEST (ID VARCHAR(100) NOT NULL,NAME VARCHAR(100) NULL,CODE VARCHAR(100) NULL,TITLE VARCHAR(100) NULL,CREATETIME TIMESTAMP NULL,COLUMN1 VARCHAR(100) NULL,COLUMN…

利用甘特图实现精细化项目管控

在项目管理中,通过精细化管控,项目经理能够有效规划、监督和协调各项任务,从而最大限度控制风险,优化资源配置,并确保按时、按质、按量完成项目目标。而在众多项目管理工具中,甘特图无疑是实现精细化项目管控的利器。zz-plan 是一个非常好用的在线甘特图制作工具&#xff0c;一…

Day78:服务攻防-数据库安全RedisCouchDBH2database未授权访问CVE漏洞

目录 前置知识 数据库应用-Redis-未授权访问&CVE漏洞 未授权访问&#xff1a;CNVD-2015-07557 未授权访问-CNVD-2019-21763 未授权访问-沙箱绕过RCE-CVE-2022-0543 数据库应用-Couchdb-未授权越权&CVE漏洞 Couchdb 垂直权限绕过&#xff08;CVE-2017-12635&…

联邦学习是怎么实现的(例子)

学习目标&#xff1a; 更加了解联邦学习 学习内容&#xff1a; 联邦学习的实现涉及多个设备或节点协同训练一个共享的机器学习模型&#xff0c;同时保持各自数据的隐私。 例子 在医疗领域中&#xff0c;不同医疗机构拥有各自的患者数据&#xff0c;但由于隐私保护法规&#…

Composer常见错误以及常用解决办法指南

Composer是一个PHP的依赖管理工具&#xff0c;它允许你声明项目所依赖的库&#xff0c;并在一个命令中安装或更新它们。在使用Composer的过程中&#xff0c;可能会遇到一些常见的错误。以下是一些常见的Composer错误及其常用的解决办法&#xff1a; “Your requirements could …

【操作系统】想要更好的学习计算机,操作系统的知识必不可少!!!

操作系统的概念 导言一、日常生活中的操作系统二、计算机系统层次结构三、操作系统的定义3.1 控制和管理计算机资源3.2 组织、调度计算机的工作与资源的分配3.3 给用户和其他软件提供方便接口与环境3.4 总结 四、操作系统的目标和功能4.1 作为管理者4.1.1 处理机管理4.1.2 存储…

CentOS 使用 Cronie 实现定时任务

CentOS 使用 Cronie 实现定时任务 文章目录 CentOS 使用 Cronie 实现定时任务一、简介二、基本使用1、常用命令2、使用示例第一步&#xff1a;创建脚本/home/create.sh第二步&#xff1a;添加定时任务第三步&#xff1a;重启 cronie 服务额外&#xff1a;查看 cronie 运行状态定…

AI创业领域的十大热门机会

目录 1.自动驾驶汽车&#xff1a; 2.人工智能助手&#xff1a; 3.机器学习解决方案&#xff1a; 4.AI驱动的医疗诊断&#xff1a; 5.机器人技术&#xff1a; 6.虚拟现实和增强现实&#xff1a; 7.金融科技&#xff1a; 8.安全与监控&#xff1a; 9.农业技术&#xff1a…

7.公约移动

7.公约移动 - 蓝桥云课 (lanqiao.cn) 问题描述 小蓝站在一个n行m列的方格图中间&#xff0c;方格图的每一个方格上都标有一个正整数。 如果两个相邻方格(上下左右四个方向相邻)内的数的最大公约数大于1&#xff0c;则可以从其中一个方格移动到另一个方格&#xff0c;当然也可以…

RocketMQ笔记(五)SpringBoot整合RocketMQ批量发送消息

目录 一、简介1.1、特点 二、Maven依赖三、application配置四、批量发送4.1、同步消息4.2、异步消息4.3、顺序消息4.4、关于异步批量发送4.5、结论 五、其他 一、简介 在之前的文章中&#xff0c;我讲过了&#xff0c;同步发送单条消息&#xff0c;异步发送单条消息&#xff0c…

yolov5目标检测可视化界面pyside6源码(无登录版)

一、软件简介&#xff1a; 这是基于yolov5-7.0目标检测实现的的可视化目标检测源码 本套项目没有用户登录的功能&#xff0c;如需用户登录版&#xff0c;看另一篇文章&#xff1a;yolov5pyside6登录用户管理目标检测可视化源码_yolov5用户登入功能-CSDN博客 ①程序中图片和图标…

稳定性生产总结

本期我们来谈下稳定性生产这个话题&#xff0c;稳定性建设目标有两个&#xff1a;降发生、降影响&#xff0c; 在降发生中的措施是做到三点&#xff1a;系统高可用、 高性能、 高质量&#xff0c;三高问题确实是一个很热的话题&#xff0c;里面涉及很多点。 在降影响中要做到…