题目描述

现给定n个闭区间[ai, bi],1<=i<=n。这些区间的并可以表示为一些不相交的闭区间的并。你的任务就是在这些表示方式中找出包含最少区间的方案。你的输出应该按照区间的升序排列。这里如果说两个区间[a, b]和[c, d]是按照升序排列的,那么我们有a<=b<c<=d。

请写一个程序:

读入这些区间;

计算满足给定条件的不相交闭区间;

把这些区间按照升序输出。

输入输出格式

输入格式:

第一行包含一个整数n,3<=n<=50000,为区间的数目。以下n行为对区间的描述,第i行为对第i个区间的描述,为两个整数1<=ai<bi<=1000000,表示一个区间[ai, bi]。

输出格式:

输出计算出来的不相交的区间。每一行都是对一个区间的描述,包括两个用空格分开的整数,为区间的上下界。你应该把区间按照升序排序。

输入输出样例

输入样例#1: 复制

5
5 6
1 4
10 10
6 9
8 10
输出样例#1: 复制

1 4
5 10 线性做法,类似于括号匹配
开始想的是线段树+二分,nlog^2n,1e6好想过不了GG
因为是在做DP时做到的,就归为DP吧
#include<cstdio>
#include<algorithm>
const int maxn = 1e6+;
inline int read() {
int x=,f=;
char c=getchar() ;
while(c<''||c>''){ if(c=='-')f=-;c=getchar();};
while(c<=''&&c>='')x=x*+c-'',c=getchar();
return x*f;
}
int n;
struct node{
int h,t;
}sth[];
int v1[maxn],v2[maxn];
int main() {
int ttt=;
n=read();
for(int a,b,i=;i<=n;++i) {
a=read();v1[a]++;
b=read(),v2[b]--;
ttt=std::max(ttt,std::max(b,a));
}
int tmp=;
int op=;
for(int i=;i<=ttt;++i) {
if(v1[i]&&!tmp) printf("%d ",i),op++;
tmp+=v1[i]+v2[i];
if(v2[i]&&!tmp) printf("%d\n",i),op++;
}
return ;
}

最新文章

  1. 2&gt;&amp;1
  2. Win8 传统桌面下无法上网的解决方法
  3. Beaglebone Black从零开始系列教程大汇总!
  4. C#小程序呢飞行棋设计分析
  5. C++写一个带参数运行的程序
  6. 20145222黄亚奇《Java程序设计》课程总结
  7. js动画 无缝轮播 进度条 文字页面展示 div弹窗遮罩效果
  8. zookeeper3.4.6的安装
  9. RobotFramework-登录
  10. SecureCRT 6.7.1 注冊机 和谐 破解 补丁 方法
  11. jQuery LigerUI V1.2.2
  12. eclipse和tomcat整合之后每次发布server.xml被修改(转)
  13. mongoDB4--mongoDB的增删改查
  14. 老李谈HTTP1.1的长连接
  15. 日积月累--线程中断interrupt()方法
  16. January 28th, 2018 Week 05th Sunday
  17. WCF开发实战系列三:自运行WCF服务
  18. 使用WebHelper调用Asp.net WebAPI
  19. OpenStack 部署总结之:单节点icehouse网桥的配置
  20. Learning Scrapy(一)

热门文章

  1. laravel5.2总结--响应
  2. jeakins配置邮件通知,附带解决535报错:authentication failed,如果发现测试邮件可以发出,项目构成无法发出邮件,请开启SSL认证,端口号改为(465),qq邮箱、163邮箱通用
  3. day02_01.能被3整除的数
  4. HTML 长文本换行
  5. Leetcode 594.最长和谐子序列
  6. [oldboy-django][4python面试]有关csrf跨站伪造请求攻击
  7. 【转】BehaviorDesigner学习
  8. Vue2.0 - 生命周期
  9. JAVA使用JDBC连接MySQL数据库 一
  10. caffe+Ubuntu14.04.10 +cuda7.0/7.5+CuDNNv4 安装