LeetCode-热题100: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 <= 104
  • intervals[i].length == 2
  • 0 <= starti <= endi <= 104

代码及注释

func merge(intervals [][]int) [][]int {res := make([][]int, 0)  // 结果数组sort.Slice(intervals, func(i, j int) bool {return intervals[i][0] < intervals[j][0]  // 按照区间的起始位置排序})if len(intervals) == 0 {return res  // 如果区间数组为空,直接返回空数组}left, right := intervals[0][0], intervals[0][1]  // 初始化左右边界为第一个区间的边界for i := 1; i < len(intervals); i++ {if intervals[i][0] <= right && intervals[i][1] > right {right = intervals[i][1]  // 更新右边界} else if intervals[i][0] > right {res = append(res, []int{left, right})  // 当前区间与前一个区间无重叠,将前一个区间添加到结果数组left, right = intervals[i][0], intervals[i][1]  // 更新左右边界}}res = append(res, []int{left, right})  // 添加最后一个合并后的区间return res
}

代码解释

  1. 初始化结果数组:

    • res 是用于存储合并后的区间的结果数组。
  2. 按照区间的起始位置排序:

    • 使用 sort.Slice 函数对 intervals 数组按照区间的起始位置进行排序。
  3. 处理边界情况:

    • 如果 intervals 数组为空,直接返回空的结果数组 res
    • 初始化左右边界为第一个区间的边界 intervals[0][0]intervals[0][1]
  4. 合并区间:

    • 遍历排序后的 intervals 数组。
    • 如果当前区间的起始位置 intervals[i][0] 小于等于当前的右边界 right 且当前区间的结束位置 intervals[i][1] 大于当前的右边界 right,更新右边界 right
    • 如果当前区间的起始位置 intervals[i][0] 大于当前的右边界 right,表示当前区间与前一个区间无重叠,将前一个区间 [left, right] 添加到结果数组 res,然后更新左右边界。
  5. 添加最后一个区间:

    • 遍历完成后,将最后一个合并后的区间 [left, right] 添加到结果数组 res
  6. 返回结果:

    • 返回结果数组 res

这段代码的时间复杂度是 O(nlogn),其中 n 是区间的数量,因为需要对区间进行排序。

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

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

相关文章

接口自动化测试流程、工具与实践详解

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、接口自动化测试简介 接口自动化测试是指通过编写脚本或使用自动化工具&#xff0c;对软件系…

conda删除虚拟环境

基于大模型生成 在 Anaconda 或 Miniconda 中&#xff0c;要删除已经创建的虚拟环境&#xff0c;您可以按照以下步骤操作&#xff1a; 打开 Anaconda Prompt&#xff08;Windows&#xff09;或终端&#xff08;Linux/macOS&#xff09;。 确保您当前不在要删除的虚拟环境下&am…

在企业微信里面添加h5页面 进行登录授权

1.需求&#xff1a;在企业微信里面添加h5页面 进行登录授权&#xff0c;获取到用户的code&#xff0c;进行登入id的验证 2.步骤&#xff1a; 根据企业微信开发者中心中构造网页授权链接进行授权 在企业微信内部进行配置&#xff0c;拿到appid&#xff0c;redirect_uri&#x…

Python实现一个简单的银行管理系统GUI应用

介绍 在本教程中&#xff0c;我们将创建一个基本的银行管理系统GUI应用&#xff0c;用户可以通过图形界面执行各种银行操作。我们将使用Python编程语言和Tkinter库来实现此应用。 使用说明 需要安装Python解释器&#xff0c;以及PythonCharm &#x1f449; 点我去下载 效果图…

通俗易懂:MySQL中如何用SQL语句模拟栈或队列的操作?

在MySQL中&#xff0c;虽然没有内建的栈或队列数据结构&#xff0c;但可以通过创建表并利用特定的SQL语句来模拟栈和队列的行为。以下是模拟栈和队列操作的基本方式&#xff1a; ### 模拟栈操作 栈&#xff08;Stack&#xff09;遵循“后进先出”&#xff08;LIFO&#xff09…

Qt/C++通用跨平台Onvif工具/支持海康大华宇视华为天地伟业等/云台控制/预置位管理/工程调试利器

一、前言 在安防视频监控行业&#xff0c;Onvif作为国际标准&#xff0c;几乎主要的厂商都支持&#xff0c;不仅包含了国内的厂商&#xff0c;也包括主要的国际厂商&#xff0c;由于有了这个标准的存在&#xff0c;使得不同设备不同安防平台之间&#xff0c;能够接入各个厂家的…

LeetCode刷题--- 等差数列划分 II - 子序列

个人主页&#xff1a;元清加油_【C】,【C语言】,【数据结构与算法】-CSDN博客 个人专栏 力扣递归题 http://t.csdnimg.cn/yUl2I 【C】 ​​​​​​http://t.csdnimg.cn/6AbpV 数据结构 ​​​http://t.csdnimg.cn/hKh2l 前言&#xff1a;这个专栏主要讲述动态规划算…

pytorch笔记篇:pandas之数据预处理(更新中)

pytorch笔记篇:pandas之数据预处理 pytorch笔记篇:pandas之数据预处理(更新中)测试例代码相关的算子pytorch笔记篇:pandas之数据预处理(更新中) 测试例代码 print(train_data.iloc[0:4, [0, 1, 2, 3, -3, -2, -1]]) # (※1) 为什么test_data的列最后不是-1,是因为test_da…

Android_ android使用原生蓝牙协议_连接设备以后,给设备发送指令触发数据传输---Android原生开发工作笔记167

之前通过蓝牙连接设备的时候,直接就是连接上蓝牙以后,设备会自动发送数据,有数据的时候,会自动发送,但是,有一个设备就不会,奇怪了很久,设备启动了也连接上了,但是就是没有数据过来. 是因为,这个设备有几种模式是握力球,在设备连接到蓝牙以后,需要,给设备通过蓝牙发送一个指令…

ensp配置acl高级配置访问控制列表

拓扑结构 资源已上传 acl访问控制列表 简单配置&#xff1a;控制目的ip地址 高级配置&#xff1a;源ip地址&#xff0c;目的ip地址等。 要求&#xff1a;拓扑三个vlan 10&#xff0c;20&#xff0c;30&#xff0c;通过设置acl使10网段可以访问20网段&#xff0c;但是不可以…

音视频处理 - 音频概念详解,码率,采样率,位深度,声道,编码

1. 音频采样 与视频不同&#xff0c;音频的最小单位不是一帧&#xff0c;而是一个采样。 采样是当前一刻声音的声音样本&#xff0c;样本需要经过数字转换才能存储为样本数据。 真实声音是连续的&#xff0c;但是在计算机中&#xff0c;声音是离散且均匀的声音样本。 2. 位深…

【Mysql数据库基础08】事务、视图的创建和修改

事务和视图 1 事务1.1 事务的介绍 ACID1.2 演示事务的使用步骤1.2.1 事例&#xff1a;张无忌转账500给赵敏 1.3 事务并发问题的介绍1.4 "删除"在事务中的区别 2 视图2.1 视图的介绍2.2 视图的创建2.3 视图的修改2.3.1 方式一 create or replace view2.3.2 方式二 alt…

DaisyDisk for mac 苹果电脑磁盘清理工具

DaisyDisk for Mac是一款直观易用的磁盘空间分析工具&#xff0c;专为Mac用户设计&#xff0c;旨在帮助他们快速识别和管理磁盘上的文件与文件夹&#xff0c;从而释放存储空间。 软件下载&#xff1a;DaisyDisk for mac 激活版 DaisyDisk采用独特的可视化界面&#xff0c;将磁盘…

洋河稳中向好,前三季度营收302.83亿元超去年全年

执笔 | 尼 奥 编辑 | 萧 萧 10月27日&#xff0c;洋河股份公布2023年前三季度业绩报告&#xff0c;这份关键性指标持续向好、超预期的“成绩单”引发业内强烈关注&#xff0c;在白酒行业调整中发挥名酒“压舱石”的积极作用&#xff0c;持续看好洋河高质量增长。 业绩报告显示…

Shadow Tactics

本题链接&#xff1a; 题目&#xff1a; 样例&#xff1a; 输入 1 1 3 3 U 2 2 2 输出 YES 思路&#xff1a; 根据题意&#xff0c;隼人的坐标是不会动的&#xff0c;并且士兵只能直线来回行动。 所以这里我们需要分成三种情况。 1、隼人坐标在士兵走动路线之间&#xff0c;…

Linux 网站定时备份+滚动删除脚本:文件、数据库(命令篇)

为确保数据安全&#xff0c;我们定期对网站相关文件和数据进行备份&#xff0c;以防止因各种原因导致的丢失情况。同时&#xff0c;考虑到服务器空间的限制&#xff0c;我们也会定期清理历史备份数据。 本文以 CentOS 7.9 系统为例&#xff0c;记录如何通过脚本和定时任务实现备…

通过修改ospf的COST值来控制路由选路

配置好OSPF之后,发现默认走的是上面 PC1>tracert 192.168.200.1traceroute to 192.168.200.1, 8 hops max (ICMP), press Ctrl+C to stop1 192.168.100.254 16 ms <1 ms 16 ms2 10.10.10.2 15 ms &l

Python 文件操作-1

目录 打开文件 OS库 打开文件 open()方法 Python 的 open() 方法用于打开一个文件&#xff0c;并返回文件对象&#xff0c;在对文件进行处理过程都需要使用到这个函数&#xff0c;如果该文件无法被打开&#xff0c;会抛出 OSError。 注意&#xff1a; 使用 open() 方法一定…

Java | 自由落体与反弹距离计算

大家可以关注一下专栏&#xff0c;方便大家需要的时候直接查找&#xff0c;专栏将持续更新~ 题目描述 编写一个Java程序&#xff0c;计算一个球从100米高度自由落下&#xff0c;每次落地后反弹回原高度的一半的距离。求这个球在第10次落地时&#xff0c;总共经过的距离和第1…

探究QUIC协议:基于UDP的可靠传输之路

为什么需要基于 UDP 实现可靠传输 主要是 TCP 协议四个方面的缺陷&#xff1a; 升级 TCP 的工作很困难&#xff1b;TCP 建立连接的延迟&#xff1b;TCP 存在队头阻塞问题&#xff1b;网络迁移需要重新建立 TCP 连接&#xff1b; 因此&#xff0c;基于UDP实现可靠传输并不是重…