news 2026/6/20 0:14:39

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/15 9:29:34

Informed RRT*实现椭圆启发式采样

我来为您添加Informed RRT*功能&#xff0c;在找到第一条路径后使用椭圆采样来加速收敛。以下是需要新增的函数和修改&#xff1a; 以下代码只含新增的部分 class RRTStar { private:// 在私有成员变量中添加bool pathFound;double bestPathCost;std::shared_ptr<Node> g…

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

27.MPSOC FPGA 驱动PCF8574

上一篇记录了AHT20,本篇记录下PCF8574&#xff0c;原理类似&#xff1a;#include <stdio.h> #include <stdlib.h> #include <fcntl.h> #include <unistd.h> #include <sys/ioctl.h> #include <linux/i2c-dev.h> #include <errno.h> …

作者头像 李华
网站建设 2026/6/15 20:47:16

通信系统仿真:数字调制与解调技术_(28).Simulink通信系统仿真

Simulink通信系统仿真 1. Simulink概述 1.1 Simulink简介 Simulink是MATLAB的一个附加产品&#xff0c;主要用于动态系统建模、仿真和分析。Simulink提供了一个图形用户界面&#xff08;GUI&#xff09;&#xff0c;使用户可以通过拖放操作来构建复杂的系统模型。在通信系统仿真…

作者头像 李华
网站建设 2026/6/19 7:08:20

论文AIGC率太高?5个超实用降AI工具分享,AI率降低80%以上

最近身边好多同学都在为论文的AI率头疼。明明自己认真改过好几遍了&#xff0c;查重系统还是显示AIGC率爆表&#xff0c;导师那关根本过不去。现在用AI工具辅助确实提升了效率&#xff0c;但怎么让内容更“人性化”&#xff0c;避免被系统标红&#xff0c;这才是关键。 我自己试…

作者头像 李华
网站建设 2026/6/17 16:11:56

团队合并与拆分的判断标准

团队合并与拆分的判断标准&#xff0c;核心是服务于组织的战略目标、效率和敏捷性。合并的判断标准主要基于“协同增效”和“规模效益”&#xff0c;当多个团队目标高度一致、资源重叠或需要集中力量办大事&#xff08;如攻坚核心项目&#xff09;时&#xff0c;应考虑合并。 而…

作者头像 李华