Hard-题目22:56. Merge Intervals

原创 2016年05月31日 23:35:20

题目原文:
Given a collection of intervals, merge all overlapping intervals.

For example,
Given [1,3],[2,6],[8,10],[15,18],
return [1,6],[8,10],[15,18].
题目大意:
给出区间集合,求出并集。
题目分析:
空间换时间,先开一个数组代表数轴(经反复测试开到4000就够了),然后记录下原集合中有的数,再扫一遍这个数组,记录下新的区间即可。需要注意的是有单点的情况,如果是传统oj直接给出wa还真的不知道怎么办。。。。
源码:(language:java)

public class Solution {
    public List<Interval> merge(List<Interval> intervals) {
        boolean[] x = new boolean[4000];
        boolean[] dots = new boolean[4000];
        int max = Integer.MIN_VALUE,min = Integer.MAX_VALUE;
        List<Interval> list = new ArrayList<Interval>();
        for(Interval interval : intervals) {
            for(int i=interval.start;i<interval.end;i++) {
                x[i]=true;
                if(i<min)
                    min=i;
                if(i>max)
                    max=i;
            }
        }

        int i = min;
        while(i<=max) {
            if(!x[i]) {
                i++;
                continue;
            }
            int start=i,end=start;
            while(x[end])
                end++;
            list.add(new Interval(start,end));
            i=end;

        }
        for(Interval interval : intervals) {
            int start = interval.start,end = interval.end;
            if(start==end && !dots[interval.start]) {
                dots[start] = true;
                if(start==0 && !x[0])
                    list.add(new Interval(start, end));
                else if(!x[start] && !x[start-1])
                    list.add(new Interval(start, end));
            }

        }
        return list;
    }
}

成绩:
5ms,beats 98.15%,众数15ms,18.26%
cmershen的碎碎念:
其实,本题正常的做法应该是对区间排序,自定义一个Comparator,我采用了取巧的办法,当然也是因为test case 的数据太弱了,如果数据范围不是4000而是4亿,则此方法行不通。

版权声明:完整版Leetcode题解请出门左转https://github.com/cmershen1/leetcode/tree/master/docs

LeetCode_56---Merge Intervals

Given a collection of intervals, merge all overlapping intervals. For example, Given [1,3],[2,6],[...

Leetcode #56. Merge Intervals 间隔合并 解题报告

1 解题思想这道题虽然标记的是Hard,但是我觉得至多Middle的难度吧,题目是给了很多区间,中间可能有重叠,现在就让你将他进行合并。首先对于这个问题,我们肯定要排序!按照什么排序么?,注意到我们是...
  • MebiuW
  • MebiuW
  • 2016年04月26日 23:54
  • 641

56. Merge Intervals\113. Path Sum II\211. Add and Search Word - Data structure design

Merge Intervals 题目描述 代码实现 Path Sum II 题目描述 代码实现56. Merge Intervals题目描述Given a collection of interval...

leetcode题解-55. Jump Game && 56. Merge Intervals

55, 题目:Given an array of non-negative integers, you are initially positioned at the first index of t...

56. Merge Intervals 对区间进行合并

Given a collection of intervals, merge all overlapping intervals. For example, Given [1,3],[2,6]...

[LeetCode]56.Merge Intervals

【题目】 Given a collection of intervals, merge all overlapping intervals. For example, Given [1,3],[...

LeetCode 56. Merge Intervals

LeetCode 56. Merge Intervals

[leetcode]56. Merge Intervals(Java)

https://leetcode.com/problems/merge-intervals/#/description Given a collection of interva...

56. Merge Intervals

合并间隔

leetCode 56.Merge Intervals (合并区间) 解题思路和方法

Merge Intervals  Given a collection of intervals, merge all overlapping intervals. For example...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Hard-题目22:56. Merge Intervals
举报原因:
原因补充:

(最多只允许输入30个字)