开发者

C语言题解Leetcode56合并区间实例

开发者 https://www.devze.com 2023-01-06 10:42 出处:网络 作者: itbird01
目录解题思路解题遇到的问题后续需要总结学习的知识点解题思路 题目链接 56. 合并区间
目录
  • 解题思路
    • 解题遇到的问题
    • 后续需要总结学习的知识点

解题思路

题目链接 56. 合并区间

本质在于两两做对比,如果两个区间,可以合并,则为结果二维数http://www.devze.com组中的一员,如果不可合并,则放入结果二维数组,所以根python本在于,如何判断两个区间,是可合并,还是不可合并

1.首先将二维数组,按照左端元素进行排序

2.将第一个元素放入结果区间列表

3.如果当前区间的左端元素比结python果区间列表最后一个区间右端元素小,则存在包含关系,此时只需更新右端元素即可 (更新为当前区间的右端元素与结果区间的右端元素的最大值)

4.如果不包含,则将当前区间加入结果区间列表,作为最后一个区间 5.输出结果区间列表

解题遇到的问题

1.二维数组排序

2.二维数组在不知道大小时,如何初始化?

后续需要总结学习的知识点

  • Arrays.copyOf源码和使用方法总结
  • 二维数组排序、重新compare
## 解法1
class Solution {
	public int[][] merge(int[][] 开发者_Js入门intervals) {
		Arrays.sort(ijsntervals, new Comparator<int[]>() {
			@Override
			public int compare(int[] o1, int[] o2) {
				return o1[0] - o2[0];
			}
		});

		int index = 0;
		for (int i = 1; i < intervals.length; i++) {
			if (intervals[index][1] < intervals[i][0]) {
				index++;
				intervals[index][0] = intervals[i][0];
				intervals[index][1] = intervals[ipython][1];
			} else {
				intervals[index][1] = Math.max(intervals[i][1],
						intervals[index][1]);
			}
		}
		return Arrays.copyOf(intervals, index + 1);
	}
}

以上就是C语言题解Leetcode56合并区间实例的详细内容,更多关于C语言 Leetcode合并区间的资料请关注我们其它相关文章!

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号