51nod 1091 线段的重叠【贪心/区间覆盖类】
第1行:线段的数量N(2 <= N <= 50000)。
第2 - N + 1行:每行2个数,线段的起点和终点。(0 <= s , e <= 10^9)
输出最长重复区间的长度。
5
1 5
2 4
2 8
3 7
7 9
4 【分析】:(http://www.cnblogs.com/ECJTUACM-873284962/p/6665489.html?utm_source=itdadao&utm_medium=referral)
首先: 先将输入的区间起点按升序排序,若起点相同则按终点降序排序
比如5组区间:(1 5)(2 4)(2 8)(3 7)(7 9)
按上面所述排序: (1 5) (2 8) (2 4) (3 7) (7 9)
这样很直观,为什么要起点升序,起点相同则按终点降序排序
起点升序很容易理解,我们要找区间覆盖最大长度。
起点相同则按终点降序排序 明显(1 5)(2 8) 区间覆盖长度大于 (1 5)(2 4)
1区间覆盖
2区间包含跟不包含(一起处理) (应该选定一个参考区间)
1 区间覆盖: 直接是小区间的距离(2 8)(2 4) 直接是4-2=2;
2 区间包含跟不包含: 区间包含,就是第一个区间终点跟第二个区间起点的差值,eg: (1 5) (2 8) 即5-2=3
假如(1 5)是参考区间,那么比较完(1 5) (2 8)。参考区间应该为下一个区间,即(2 8).
因为后面的区间起始点都不比(2 8)小(起点升序)。又因为区间包含,就是第一个区间终点跟第二个区间起点的差值。
那么后面的区间跟(1 5)区间覆盖长度都没有比(2 8)区间覆盖长度大。所以这时再以(1 5)作为参考区间没有意义了。
为方便起见,就选取下一个区间作为参考区间,即(2 8).
总结一下:
1.先将输入的区间起点按升序排序,若起点相同则按终点降序排序
2.分两部分处理:区间覆盖+区间包含跟不包含
【代码】:
#include <bits/stdc++.h> using namespace std;
struct node
{
int l,r;
}a[+]; bool cmp(node a,node b)
{
if(a.l!=b.l)
return a.l<b.l;
else
{
if(a.r!=b.r)
return a.r>b.r;
}
}
int main()
{
int n,ans;
while(cin>>n)
{
ans=;
for(int i=;i<n;i++)
cin>>a[i].l>>a[i].r;
sort(a,a+n,cmp);
node m=a[];
for(int i=;i<n;i++)
{
if(a[i].r<=m.r)
ans=max(ans, a[i].r-a[i].l);
else
{
ans=max(ans, m.r-a[i].l);
m=a[i];
}
}
cout<<ans<<endl;
}
return ;
}
51nod 1091 线段的重叠【贪心/区间覆盖类】的更多相关文章
- 51Nod 1091 线段的重叠(贪心+区间相关,板子题)
1091 线段的重叠 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题 X轴上有N条线段,每条线段包括1个起点和终点.线段的重叠是这样来算的,[10 2 ...
- 51Nod 1091 线段的重叠(贪心+区间相关
1091 线段的重叠 X轴上有N条线段,每条线段包括1个起点和终点.线段的重叠是这样来算的,[10 20]和[12 25]的重叠部分为[12 20]. 给出N条线段的起点和终点,从中选出2条线段,这两 ...
- [51nod] 1091 线段的重叠 贪心
X轴上有N条线段,每条线段包括1个起点和终点.线段的重叠是这样来算的,[10 20]和[12 25]的重叠部分为[12 20]. 给出N条线段的起点和终点,从中选出2条线段,这两条线段的重叠部分是最长 ...
- 51Nod 1091 线段的重叠 (贪心)
X轴上有N条线段,每条线段包括1个起点和终点.线段的重叠是这样来算的,[10 20]和[12 25]的重叠部分为[12 20]. 给出N条线段的起点和终点,从中选出2条线段,这两条线段的重叠部分是最长 ...
- 51 Nod 1091 线段的重叠 (贪心算法)
原题链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1091 思路分析:通过读题不难发现这是一道涉及贪心算法的题,刚 ...
- 【题解】Cut the Sequence(贪心区间覆盖)
[题解]Cut the Sequence(贪心区间覆盖) POJ - 3017 题意: 给定一大堆线段,问用这些线段覆盖一个连续区间1-x的最小使用线段的数量. 题解 考虑一个这样的贪心: 先按照左端 ...
- 高效算法——E - 贪心-- 区间覆盖
E - 贪心-- 区间覆盖 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=85904#problem/E 解题思路: 贪心思想, ...
- nyoj 12——喷水装置二——————【贪心-区间覆盖】
喷水装置(二) 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 有一块草坪,横向长w,纵向长为h,在它的橫向中心线上不同位置处装有n(n<=10000)个点状的 ...
- UVA 10382 - Watering Grass【贪心+区间覆盖问题+高精度】
UVa 10382 - Watering Grass n sprinklers are installed in a horizontal strip of grass l meters long a ...
随机推荐
- VS的几个实用快捷键
Ctrl + K, D格式化代码 Ctrl + L 删除一行 Ctrl + K, S调出自动代码块 svm之后二下TAB 生成Main方法 Ctrl + K,C注释代码块Ctrl+K,U取消注释
- Eclipse安装使用
1.访问https://www.eclipse.org/downloads/下载最新的Eclipse工具包或者百度通过其他路径下载需要的版本 2.下载完成后将压缩包进行解压的得到相应的文件 3.进入解 ...
- 【java并发编程实战】第一章笔记
1.线程安全的定义 当多个线程访问某个类时,不管允许环境采用何种调度方式或者这些线程如何交替执行,这个类都能表现出正确的行为 如果一个类既不包含任何域,也不包含任何对其他类中域的引用.则它一定是无状态 ...
- 课时2:用python设计第一个游戏
目录: 一.第一个小游戏 二.缩进 三.BIF 四.课时02课后习题及答案 ********************* 一.第一个小游戏 ********************* # p2_1.py ...
- jquery实现各种实例
1.正反选实例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- HDU 4472 Count (DP)
题目:问n个节点构成完全对称的树有多少种方法. 因为树是完全对称的,所以它的子树也是完全对称的. 对于每个树,拿出一个根节点,枚举剩下的节点能拆分成多少个子树. #include <cstdio ...
- NIO--1
1.为什么不直接用jdk NIO(1) API繁杂(2) 原始NIO可靠性不是很高.可靠性包括:断开重连,网络闪断,半包读写,失败缓存(3) NIO 的epoll BUG会导致多路复用器Selecto ...
- Linq 聚合函数
var WReserve = (from m in _db.W_RESERVE select m).ToList().LastOrDefault(); 必须ToList() 之后才能 last fir ...
- HDU 6034 Balala Power!(贪心+排序)
Balala Power! Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...
- [poj] 3090 Visible Lattice Points
原题 欧拉函数 我们发现,对于每一个斜率来说,这条直线上的点,只有gcd(x,y)=1时可行,所以求欧拉函数的前缀和.2*f[n]+1即为答案. #include<cstdio> #def ...