51Nod 1091 线段的重叠(贪心+区间相关,板子题)
X轴上有N条线段,每条线段包括1个起点和终点。线段的重叠是这样来算的,[10 20]和[12 25]的重叠部分为[12 20]。
第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.51nod.com/onlineJudge/questionCode.html#!problemId=1091
分析:
这道题对初学者看似很复杂,其实认真分析就会发现很简单。。
(下面结合例子分析一下)(本人非常弱,大神莫见笑)
首先: 先将输入的区间起点按升序排序,若起点相同则按终点降序排序
比如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.分两部分处理:区间覆盖 区间包含跟不包含
下面给出AC代码:
#include <bits/stdc++.h>
using namespace std;
const int maxn=;
struct node
{
int start,end;
}p[maxn];
int ans=;
int n;
bool cmp(node x,node y)
{
if(x.start<y.start)
return true;
if(x.start==y.start&&x.end>y.end)
return true;
return false;
}
int main()
{
scanf("%d",&n);
for(int i=;i<n;i++)
scanf("%d%d",&p[i].start,&p[i].end);
sort(p,p+n,cmp);//起点升序 若起点相同,终点降序
node m=p[];
for(int i=;i<n;i++)
{
if(p[i].end<=m.end)//区间覆盖
ans=max(ans,p[i].end-p[i].start);
else
{
ans=max(ans,m.end-p[i].start);//覆盖跟不覆盖
m=p[i];//更新前一个区间
}
}
printf("%d\n",ans);
return ;
}
51Nod 1091 线段的重叠(贪心+区间相关,板子题)的更多相关文章
- 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 线段的重叠【贪心/区间覆盖类】
1091 线段的重叠 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题 收藏 关注 X轴上有N条线段,每条线段包括1个起点和终点.线段的重叠是这样来算的,[10 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 思路分析:通过读题不难发现这是一道涉及贪心算法的题,刚 ...
- HDU 2037 今年暑假不AC(贪心,区间更新,板子题)
今年暑假不AC Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Su ...
- 51Nod 1091 线段重叠 | 贪心
Input示例 5 1 5 2 4 2 8 3 7 7 9 Output示例 4 first try: O(n^2):二层循环,减法取最大 后五个time limit exceeded #includ ...
- 51 Nod 1091 线段的重叠
2017-09-24 19:51:41 writer:pprp 上一个题目就是关于线段重叠最大值,这个是找区间最长重合? 给你n个线段,然后让你在其中选择两条,使两条尽可能重合多一点 解决方法; 1. ...
- 【51nod-1091】线段的重叠(贪心)
所有线段按起点从小到大排序,然后比较出最大的重叠部分.比如第i条线段和第j条线段进行比较找出重叠部分(j>i),当第j条线段的右端点<第i条线段的右端点,此时可以让i继续比较后面的线段:如 ...
随机推荐
- Android 开发,你遇上 Emoji 头疼吗?
在 Android 中,如果需要使用的到 Emoji 表情,你会发现在某些设备上,有一些 Emoji 表情会被以豆腐块 "☐" 的形式显示,这是因为当前设备并不支持这个 Emoji ...
- APP闪退问题
1.iOS-中app启动闪退的原因 2.iOS开发-闪退问题-解决之前上架的 App 在 iOS 9 会闪退问题 3.iOS-应用闪退总结 4.iOS开发-捕获程序崩溃日志 5.iOS开发-应用崩溃日 ...
- discuz管理员登录进入后台管理马上跳转到登录界面
昨天尝试了一下这个discuz论坛,感觉还可以.今天刚刚用管理员账户进入后台管理,准备改一改界面熟悉一下,过不了10秒钟.老是马上就退出来了.我想起来了,昨天是在阿里云服务器上面直接登录这个管理员账号 ...
- 后缀数组之hihocoder 重复旋律1-4
蒟蒻知道今天才会打后缀数组,而且还是nlogn^2的...但基本上还是跑得过的: 重复旋律1: 二分答案,把height划分集合,height<mid就重新划分,这样保证了每个集合中的LCP&g ...
- ecsmart的开发经历
ecsmart是ecshop的产品之一,是2015年发布的一套系统.关于它的介绍请到官网去了解,也可以百度 “商之翼” “ecsmart” 1.ecsmart分别在pc.mobile.app三个方面都 ...
- 搭建和测试 Redis 主备和集群
本文章只是自我学习用,不适宜转载. 1. Redis主备集群 1.1 搭建步骤 机器:海航云虚机(2核4GB内存),使用 Centos 7.2 64bit 操作系统,IP 分别是 192.168.10 ...
- 连接虚拟机mysql无法访问,报错编号1130的解决方法
新装一台虚拟机mysql的时候,往往会出现win无法连接的情况,报错信息1130,是因为没有权限的问题,解决方案如下: mysql -u root -p mysql>use mysql; mys ...
- MyBatis中批量插入数据对插入记录数的限制
<基于Mybatis框架的批量数据插入的性能问题的探讨>(作者:魏静敏 刘欢杰 来源:<计算机光盘软件与应用> 2013 年第 19 期)中提到批量插入的记录数不能超过1000 ...
- idea为tomcat设置虚拟地址
1.设置tomcat的server.xml <Host name="localhost" appBase="webapps" unpackWARs=&qu ...
- .net 4.5 webform 提取ModelState错误信息
.net4.5以后,webform也可以使用模型绑定和模型验证. user实体: public class User { [Required] [Display(Name = "用户ID&q ...