news 2026/6/23 20:03:06

leetcode56.合并区间

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
leetcode56.合并区间

以数组 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

解法:

1、第一个区间的右边界(5)在第二个区间之间(4, 6),则要更新第一个区间的右边界为6;

2、第一个区间的右边界(3)小于第二个区间的左边界(4),则将第二个区间作为新增区间;

3、第一个区间的右边界(8)大于第二个区间的右边界(6),则第一个区间保持不变,第二个区间被忽略;

/** * Return an array of arrays of size *returnSize. * The sizes of the arrays are returned as *returnColumnSizes array. * Note: Both returned array and *columnSizes array must be malloced, assume caller calls free(). */ int CompareInt(const void* a, const void* b) { int* x = *(int**)a; int* y = *(int**)b; if (x[0] != y[0]) { return x[0] - y[0]; } return (x[1] - y[1]); } int** merge(int** intervals, int intervalsSize, int* intervalsColSize, int* returnSize, int** returnColumnSizes) { // qsort qsort(intervals, intervalsSize, sizeof(intervals[0]), CompareInt); int** res = (int**)malloc(sizeof(int) * intervalsSize * 2); *returnColumnSizes = malloc(sizeof(int) * intervalsSize); for (int i = 0; i < intervalsSize; i++) { res[i] = (int*)malloc(sizeof(int) * 2); } res[0] = intervals[0]; (*returnColumnSizes)[0] = 2; int cnt = 0; for (int i = 1; i < intervalsSize; i++) { if (intervals[i][0] <= res[cnt][1]) { if (intervals[i][1] > res[cnt][1]) { res[cnt][1] = intervals[i][1]; } } else { cnt++; res[cnt] = intervals[i]; } (*returnColumnSizes)[cnt] = 2; } // go through all the element and get array *returnSize = cnt + 1; return res; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 1:54:57

云手机 实体手机的云端延伸

云手机可视为实体手机的云端延伸。它基于云计算技术和虚拟化技术&#xff0c;在云端服务器上虚拟出带有原生安卓等操作系统的手机实例&#xff0c;通过网络与实体设备连接&#xff0c;用户可通过实体手机、平板或电脑等设备远程操控云手机&#xff0c;实现诸如运行应用、游戏等…

作者头像 李华
网站建设 2026/6/23 4:13:33

交换机和网卡的 PFC 机制工作原理与实例解析

PFC&#xff08;Priority-based Flow Control&#xff0c;基于优先级的流控&#xff09; 是数据中心以太网&#xff08;如 RoCE v2、DCB&#xff09;的核心技术&#xff0c;属于链路层&#xff08;Layer 2&#xff09;流量控制机制。其核心目标是解决拥塞导致的丢包问题—— 通…

作者头像 李华
网站建设 2026/6/22 19:58:33

UI自动化测试常见面试题

1、什么是UI自动化测试&#xff1f; UI自动化测试是一种通过模拟用户交互并自动执行UI操作的软件测试方法。它用于验证用户界面的功能和稳定性&#xff0c;以确保在不同的操作系统、浏览器和设备上的一致性。 2、UI自动化测试的优势和劣势是什么&#xff1f; 优势&#xff1…

作者头像 李华
网站建设 2026/6/23 18:10:17

Linux OOM 问题之 DMSERVER 受害者

Shell 脚本模拟(无需安装工具) OOM 问题#!/bin/bash #持续申请内存&#xff0c;每次申请 100MB&#xff0c;直到内存耗尽。while true; do # 创建 100MB 临时文件&#xff0c;读取到内存(cat 命令会占用内存)。cat /dev/zero |head -c 100M |tail & done运行脚本&#xff1…

作者头像 李华
网站建设 2026/6/23 2:05:11

Flutter引擎裁剪与鸿蒙方舟编译协同优化

欢迎大家加入开源鸿蒙跨平台开发者社区&#xff0c;一起共建开源鸿蒙跨平台生态。 Flutter引擎裁剪与鸿蒙方舟编译协同优化 Flutter引擎的冗余模块会增加包体积并影响启动速度。通过分析flutter_engine源代码&#xff0c;可识别非必要模块进行裁剪。常见可移除模块包括&#…

作者头像 李华