• [Leetcode] Merge Intevals


    Question:

    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].

    ---------------------------------------

    Solution:

    public class Solution {
        class IntervalAsc implements Comparator<Interval>
          {
            public int compare (Interval o1, Interval o2)
            {
             if (o1.start != o2.start)
                return o1.start < o2.start ? -1 : 1;
              else if (o1.end != o2.end)
                return o1.end < o2.end ? -1 : 1;
              else
                return 0;
          }}
    
          public ArrayList<Interval> merge (ArrayList<Interval> intervals)
          {
            Collections.sort(intervals, new IntervalAsc());
            ArrayList<Interval> ret = new ArrayList<Interval>();
            int n = intervals.size();
            if(n==0) return ret;
            Interval last=intervals.get(0);
            for(int i=1;i<n;i++){
                if(intervals.get(i).start>last.end){
                    ret.add(new Interval(last.start,last.end));
                    last=intervals.get(i);
                }else{
                    last.end=Math.max(intervals.get(i).end, last.end);
                }
            }
            ret.add(last);
            return ret;
          }
    
        }

    需要注意的以下几点:

    1. 这里需要new一个Interval,再放进ArrayList result里。刚开始我就是直接把last放进了result里,忘记了last只是一个类似于指针一样的东西。
    2. 第一次使用到了内部类。更多的内部类的知识看下一篇博客。
    3. Collections.sort的用法。(compare函数的重写)
  • 相关阅读:
    bootstrap不同屏幕区分数值
    jq星星评分
    大話西遊
    HDU 5353 Average 贪心
    HDU 5358 First One 数学+尺取法
    生活感受
    HDU 4372 Count the Buildings 组合数学
    暑假集训-合训第九场
    一些资料
    多校-HDU 5351 MZL's Border 数学规律
  • 原文地址:https://www.cnblogs.com/Phoebe815/p/3786188.html
Copyright © 2020-2023  润新知