博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【一天一道LeetCode】#56. Merge Intervals
阅读量:4197 次
发布时间:2019-05-26

本文共 1145 字,大约阅读时间需要 3 分钟。

一天一道LeetCode系列

(一)题目

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

(二)解题

/*本题的解题步骤:1、对vector里面的每个Interval结构体按照start的值升序排列2、遍历整个intervals,如果有重复区域就合并,如果没有就存到ret里面*//** * Definition for an interval. * struct Interval { *     int start; *     int end; *     Interval() : start(0), end(0) {} *     Interval(int s, int e) : start(s), end(e) {} * }; */class Solution {public:    vector
merge(vector
& intervals) { vector
ret; if(intervals.empty()) return ret; sort(intervals.begin(),intervals.end(),comparein);///按照start的值升序排列 Interval tmp = intervals[0];//初始化 for(int i = 1 ; i < intervals.size() ; i++) { if(intervals[i].start<=tmp.end) tmp.end = max(tmp.end,intervals[i].end);//更新end else{ ret.push_back(tmp);//没有重复区域就压入ret tmp = intervals[i];//更新tmp的值,继续遍历 } } ret.push_back(tmp); return ret; } static bool comparein(const Interval& i1 , const Interval& i2)//比较函数 { return i1.start

转载地址:http://mayli.baihongyu.com/

你可能感兴趣的文章
安装nginx
查看>>
手动6 - 隐藏Nginx版本号
查看>>
手动7 - nginx 日志切割
查看>>
magento - 使用后台设置的时间用法
查看>>
Linux常用命令
查看>>
清除文件中的.svn文件
查看>>
手动11 -nginx 优化配置
查看>>
php加速器 - zendopcache
查看>>
手动12 - 安装php加速器 Zend OPcache
查看>>
set theme -yii2
查看>>
yii2 - 模块(modules)的view 映射到theme里面
查看>>
yii2 - controller
查看>>
yii2 - 增加actions
查看>>
网站加载代码
查看>>
php图像处理函数大全(缩放、剪裁、缩放、翻转、旋转、透明、锐化的实例总结)
查看>>
magento url中 uenc 一坨编码 base64
查看>>
强大的jQuery焦点图无缝滚动走马灯特效插件cxScroll
查看>>
Yii2.0 数据库查询
查看>>
yii2 db 操作
查看>>
mongodb group 有条件的过滤组合个数。
查看>>