【力扣-数据结构基础】【第 2 天】56. 合并区间

标题56. 合并区间
难度中等
天数第2天,第2/3题
数据结构数组

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

以上内容来源:力扣(LeetCode)
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


思路:

  1. 针对数组先对左区间从小到大排序
	//左区间从小到大排列
	Arrays.sort(intervals,new Comparator<int[]>(){
		@Override
		public int compare(int[] a,int[]b){
			return a[0] - b[0];
		}
	});
  1. 创建一个用于记录返回数据的集合ans
	//返回集合
	List<int[]> ans = new ArrayList();
  1. 遍历排序后的数组,从0开始
 for(int i = 0;i < m;i++){}
  1. 合并规则
    • 条件1 集合ans存在元素
    • 条件2 当前数组左区间<= 集合ans最后一个数组的右区间
    • 例:ans是[1,3] 当前是[2,5]
    • 当前左区间是2,集合ans右区间是3 ,那么就符合规则2 <= 3就合并
	int ansSize =  ans.size();
	//返回集合存在元素,并且,当前左区间 <= 集合中最后一个数组的右区间,那么就合并
	if(ansSize > 0 && intervals[i][0] <= ans.get(ansSize - 1)[1]){
		ans.get(ansSize-1)[1] = Math.max(ans.get(ansSize-1)[1],intervals[i][1]);
	}
  1. 添加规则,
    • 如果是第一个元素直接添加
    • 如果数组左区间> 集合最后一个数组右区间 就直接添加
	ans.add(intervals[i]);
  1. 最后通过List.toArray方法将集合转化成二维数组返回

完整代码:

class Solution {
    //数据结构基础 第二天  数组  2/3
    public int[][] merge(int[][] intervals) {
        int m = intervals.length;
        if(m == 1){
            return intervals;
        }
        //左区间从小到大排列
        Arrays.sort(intervals,new Comparator<int[]>(){
            @Override
            public int compare(int[] a,int[]b){
                return a[0] - b[0];
            }
        });
        //返回集合
        List<int[]> ans = new ArrayList();

        for(int i = 0;i < m;i++){
            int ansSize =  ans.size();
            //返回集合存在元素,并且,当前左区间 <= 集合中最后一个数组的右区间,那么就合并
            if(ansSize > 0 && intervals[i][0] <= ans.get(ansSize - 1)[1]){
                ans.get(ansSize-1)[1] = Math.max(ans.get(ansSize-1)[1],intervals[i][1]);
            }else{
                //第一个数组,或者是不能合并的数组直接添加进集合
                ans.add(intervals[i]);
            }
        }
        //集合转换为二维数组
        return ans.toArray(new int[ans.size()][2]);
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Crazy丶code

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值