zoukankan      html  css  js  c++  java
  • [Leetcode] merge intervals 合并区间

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

    题意:给定一系列区间,合并重叠区间

    思路:其实,个人觉得,题目的例子有一定误导性,以为区间已经按每个区间的start值排好序了。结果,毫无疑问,悲剧了。若是已经排好序,则,只需将当前区间的end值和下一个的start值比较,若是,before.end>=next.start,说明两个区间有重合,只需将后者的end值赋给前者的end值就行; before.end<next.start说明没有重叠,这样,就将前者存入结果,然后访问下一个就行。那么关键点来了,如何给这些区间排序?我们可以使用向算法传递函数,使用sort的第二版本,它接受第三个参数(为一个谓词),关于泛型算法,我将后续中给出较为详细的讲解。代码如下:

     1 /**
     2  * Definition for an interval.
     3  * struct Interval {
     4  *     int start;
     5  *     int end;
     6  *     Interval() : start(0), end(0) {}
     7  *     Interval(int s, int e) : start(s), end(e) {}
     8  * };
     9  */
    10 class Solution {
    11 public:
    12     static bool compare(const Interval &a,const Interval &b)
    13     {
    14         return a.start<b.start;
    15     }
    16 
    17     vector<Interval> merge(vector<Interval> &intervals) 
    18     {
    19         
    20         vector<Interval> res;
    21         int len=intervals.size();  
    22         if(len==0)  return res; 
    23         sort(intervals.begin(),intervals.end(),compare);
    24         res.push_back(intervals[0]);
    25 
    26         for(int i=1;i<len;++i)
    27         {
    28             int rLen=res.size();
    29             if(res[rLen-1].end>=intervals[i].start)
    30             {
    31                 res[rLen-1].end=max(res[rLen-1].end,intervals[i].end);
    32             }
    33             else
    34                 res.push_back(intervals[i]);
    35         } 
    36         return res;
    37     }
    38 };

    在上述代码中,第28行,因为我们要实时访问res的最后一个区间的end值,但res是在变化的,所以通过这种方式访问,当然也可以通过使用back函数来访问以下方式:

     1 for(int i=1;i<intervals.size();++i)
     2 {
     3     if(res.back().end>=intervals[i].start)
     4     {
     5         res.back().end=max(res.back().end,intervals[i].end);
     6     }
     7     else
     8     {
     9         res.push_back(intervals[i]);
    10     }
    11 }
  • 相关阅读:
    记开发个人图书收藏清单小程序开发(二)
    记一次使用MemoryCache不能Get的问题
    Linux:系统安全相关优化,(firewalld、iptables、selinux)
    linux:操作系统优化
    Linux:日志,cpu,memory,mount,load等系统信息查看
    linux:yum系统如何安装软件
    Linux:系统运行级别
    linux:eth0(ens33)-网卡名称及配置文件信息解析
    linux:linux系统中的挂载技术
    linux:命令行常用快捷方式
  • 原文地址:https://www.cnblogs.com/love-yh/p/7101756.html
Copyright © 2011-2022 走看看