• [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函数的重写)
  • 相关阅读:
    page指令
    CMD设IP
    JDBC的几种驱动
    Python的闭包使用
    1189. 扫雷游戏
    1287. 递增的三元子序列
    Pip安装使用国内源的两种方法
    Python Classmethod和Staticmethod函数
    Git提交远程仓库
    Git分支管理
  • 原文地址:https://www.cnblogs.com/Phoebe815/p/3786188.html
Copyright © 2020-2023  润新知