news 2026/4/17 7:59:53

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/4/13 9:11:57

云手机存在哪些技术瓶颈

云手机需在服务器上虚拟化出与真实手机一致的运行环境&#xff0c;目前多采用 ARM 服务器方案&#xff0c;但相关技术迁移尚未完全普及&#xff0c;仍存在硬件功耗、能效比等方面的问题&#xff0c;且对移动端应用的兼容性有待提升&#xff0c;可能出现游戏渲染卡顿、多任务切换…

作者头像 李华
网站建设 2026/4/18 5:22:41

从关系型数据库到时序数据库的思维转变

一、核心范式转变&#xff1a;从“实体关系”到“时间流事件” 维度关系型数据库 (RDBMS)时序数据库 (TSDB)核心抽象​实体与关系。世界由“学生”、“订单”、“产品”等实体构成&#xff0c;通过外键关联。带时间戳的测量流。世界是持续变化的“指标”&#xff0c;如“CPU温…

作者头像 李华
网站建设 2026/4/15 15:57:53

拿一句 “油腻情话”,把你家男人甜到起鸡皮疙瘩

1️⃣ 你能帮我递个东西吗&#xff1f;递什么&#xff1f;递我的真心给你呀&#xff5e;2️⃣ 你是属磁铁的吧&#xff1f;不然我怎么老想黏着你&#xff01;3️⃣ 今天喝了杯奶茶&#xff0c;什么茶&#xff1f;想你想到茶不思饭不想&#xff5e;4️⃣ 我最近在练一项技能&…

作者头像 李华
网站建设 2026/4/18 0:38:02

AI产品经理转型+大模型实战:收藏这套系统化学习资源,小白也能变专家

文章介绍AI产品经理职责、与传统产品经理的区别(需懂技术)、类型分类及必备技能&#xff0c;重点分享AI大模型学习资源&#xff0c;包括七阶段学习路线、300视频教程、数百本技术文档和面试题&#xff0c;帮助小白和程序员系统掌握大模型应用开发技能。1.AI产品经理是什么 回答…

作者头像 李华
网站建设 2026/4/18 7:39:33

基于Vue的电商后台管理系统的设计与实现qyf0i(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末

系统程序文件列表 系统功能 用户,商品分类,品牌信息,商家,商品信息,促销商品,咨询商家 开题报告内容 《基于Vue的电商后台管理系统的设计与实现》开题报告 一、选题背景、研究意义及国内外研究现状 1. 选题背景 随着互联网技术的快速发展和数字化转型的深入推进&#xff0…

作者头像 李华