luogu P2434 [SDOI2005]区间
2024-08-29 08:18:09
题目描述
现给定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 ;
}
最新文章
- 2>;&;1
- Win8 传统桌面下无法上网的解决方法
- Beaglebone Black从零开始系列教程大汇总!
- C#小程序呢飞行棋设计分析
- C++写一个带参数运行的程序
- 20145222黄亚奇《Java程序设计》课程总结
- js动画 无缝轮播 进度条 文字页面展示 div弹窗遮罩效果
- zookeeper3.4.6的安装
- RobotFramework-登录
- SecureCRT 6.7.1 注冊机 和谐 破解 补丁 方法
- jQuery LigerUI V1.2.2
- eclipse和tomcat整合之后每次发布server.xml被修改(转)
- mongoDB4--mongoDB的增删改查
- 老李谈HTTP1.1的长连接
- 日积月累--线程中断interrupt()方法
- January 28th, 2018 Week 05th Sunday
- WCF开发实战系列三:自运行WCF服务
- 使用WebHelper调用Asp.net WebAPI
- OpenStack 部署总结之:单节点icehouse网桥的配置
- Learning Scrapy(一)
热门文章
- laravel5.2总结--响应
- jeakins配置邮件通知,附带解决535报错:authentication failed,如果发现测试邮件可以发出,项目构成无法发出邮件,请开启SSL认证,端口号改为(465),qq邮箱、163邮箱通用
- day02_01.能被3整除的数
- HTML 长文本换行
- Leetcode 594.最长和谐子序列
- [oldboy-django][4python面试]有关csrf跨站伪造请求攻击
- 【转】BehaviorDesigner学习
- Vue2.0 - 生命周期
- JAVA使用JDBC连接MySQL数据库 一
- caffe+Ubuntu14.04.10 +cuda7.0/7.5+CuDNNv4 安装