Hard-제목22:56.Merge Intervals

3569 단어
제목 원문: 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를 사용자 정의해야 한다. 나는 교묘한 방법을 사용했다. 물론 테스트 케이스의 데이터가 너무 약하기 때문이다. 만약에 데이터 범위가 4000이 아니라 4억이면 이 방법은 통하지 않는다.

좋은 웹페이지 즐겨찾기