51nod 1091 线段的重叠
来源:互联网 发布:中世纪2优化9丹麦 编辑:程序博客网 时间:2024/05/30 23:37
1091 线段的重叠
基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题
收藏
关注
X轴上有N条线段,每条线段包括1个起点和终点。线段的重叠是这样来算的,[10 20]和[12 25]的重叠部分为[12 20]。
给出N条线段的起点和终点,从中选出2条线段,这两条线段的重叠部分是最长的。输出这个最长的距离。如果没有重叠,输出0。
Input
第1行:线段的数量N(2 <= N <= 50000)。第2 - N + 1行:每行2个数,线段的起点和终点。(0 <= s , e <= 10^9)
Output
输出最长重复区间的长度。
Input示例
51 52 42 83 77 9
Output示例
4
一拿到题 ,线段树????
再仔细看了看,应该是贪心题,抱着侥幸的心理来一波 优化后的暴力,居然A了。。。
主要思路是:
1.先给差值从大到小排序
2.然后从第一条(即差值最大的线段)顺序匹配第二条线段,ans=max(ans,(l-r/*满足条件的情况下*/))。。。。。不多说,直接上代码。
#include <iostream>#include<stdio.h>#include<string.h>#include<algorithm>#include <cmath>using namespace std;typedef long long ll;struct Btree{ ll l,r;}Node[50005];int cmp(Btree a,Btree b){ return (a.r-a.l)>(b.r-b.l);}int main(){ int N; while(scanf("%d",&N)!=EOF){ for(int i=0;i<N;i++){ scanf("%lld%lld",&Node[i].l,&Node[i].r); } sort(Node,Node+N,cmp); ll ans=0; int k=0; while(1){ if((Node[k].r-Node[k].l)<ans||k==N-1) break; for(int j=k+1;j<N;j++){ if((Node[j].r-Node[j].l)<ans) break; if(Node[j].l>Node[k].r||Node[j].r<Node[k].l) continue; else if(Node[j].l>Node[k].l&&Node[j].r>Node[k].r){ ans=max(ans,Node[k].r-Node[j].l); // cout<<ans<<endl; } else if(Node[j].l<Node[k].l&&Node[k].r>Node[j].r){ ans=max(ans,Node[j].r-Node[k].l); //cout<<ans<<endl; } else{ ans=max(ans,Node[j].r-Node[j].l); //cout<<ans<<endl; } } k++; } printf("%lld\n",ans); } return 0;}
阅读全文
0 0
- 51nod-1091 . 线段的重叠
- 51nod 1091 线段的重叠(贪心)
- 51nod 1091 线段的重叠
- 51nod 1091 线段的重叠
- 51nod 1091 线段的重叠 贪心
- 51nod 1091 线段的重叠
- 51nod 1091 线段的重叠 贪心
- 贪心-51nod 1091 线段的重叠
- 51nod-【1091 线段的重叠】
- 51nod 1091 线段的重叠
- 51nod 1091 线段的重叠
- 51nod 1091 线段的重叠
- 51 NOD 1091 线段的重叠
- 51Nod 1091 线段的重叠
- 51 nod 1091 线段的重叠
- 51Nod-1091 线段的重叠【排序】
- 51Nod 1091 线段的重叠
- 51nod 1091 线段的重叠
- C#-LINQ
- 【LC解题报告】11. Container With Most Water
- 完整复现何恺明ICCV获奖论文结果并开源 !(附论文&开源代码)
- MySQL 设置允许远程登录
- JZOJ 5428. 【NOIP2017提高A组集训10.27】查询
- 51nod 1091 线段的重叠
- 修改srpingBoot Banner
- 51 nod 1003:一个数阶乘后0的个数
- 【一】如果让我学习TensorFlow,我该怎么学?
- 余额宝惨败,马云担心的事情发生了!
- 2017.10.26 測試總結并今日總結
- R 语言 wordcloud 与 wordcloud2 包的安装及参数说明
- android 解决华为 SlidingMenu出现白屏
- 活动——使用显式Intent