题目描述

现给定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]。

输出格式

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

样例

INPUT

5

5 6

1 4

10 10

6 9

8 10

OUTPUT

1 4

5 10

HINT

SOLUTION

差分

感觉差分是我们这种涉及区间的处理的问题的很重要的一个考虑方式啊qwq

接下来有10行废话。

这题不难。

我想过贪心,想过区间dp,想过建树bfs,就是没想到差分。

先看数据范围:\(3\leq n \leq 50000,1\leq a_i<b_i\leq 1000000\),

首先我们就把\(O(n^2)\)的方案给毙掉了。

这种题不是\(O(n)\)就是\(O(nlogn)\),对吧。

建树不好建,建了也不知道怎么写,毙掉。

就剩\(O(n)\)的了。

dp?怎么写啊?我不会,毙掉。

贪心把区间从头开始往后拓,直到出现断点?那万一全部连起来了呢?不好找断点,毙掉。

然后把目光放在这里:\(1\leq a_i<b_i\leq 1000000\),说不定有\(O(max(b_i))\)的写法呢?然后老老实实翻了题解。。。

所以我们考虑差分。

进来一个左端点就在相应位置+1,进来一个右端点就在相应位置-1,对,这就是典型的差分。

当我们的点的左边为正,而当前点为0,这说明有若干(也可能只有一)对区间从这里开始。

同理,当我们的点的右边为0,而当前点为0,这说明有若干(也可能只有一)对区间在这里完成了匹配,可以断开作为一段完整区间。

然后注意一下形同\([i,i]\)的区间要特判一下就可以了。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <algorithm>
using namespace std;
#define Min(a,b) ((a<b)?a:b)
#define Max(a,b) ((a>b)?a:b)
const int N=101000,M=1010000;
inline int read(){
int x=0,f=1;char ch=getchar();
while (ch<'0'||ch>'9') {if (ch=='-') f=-1;ch=getchar();}
while (ch>='0'&&ch<='9') {x=x*10+ch-48;ch=getchar();}
return x*f;}
struct NODE{int d,u;}nd[N];
bool cmp(NODE a,NODE b) {return a.d<b.d;}
struct ITV{int l,r;}ans[N];
int n,itv[M],L=M,R=0;
int main(){
int i,j;
n=read();int cnt=0;
for (i=1;i<=n;++i){
nd[++cnt].d=read();nd[cnt].u=1;L=Min(L,nd[cnt].d);R=Max(R,nd[cnt].d);
nd[++cnt].d=read();nd[cnt].u=-1;L=Min(L,nd[cnt].d);R=Max(R,nd[cnt].d);}
memset(itv,0,sizeof(itv));
sort(nd+1,nd+1+cnt,cmp);
int p=1;cnt=0;
for (i=L;i<=R;++i){
itv[i]=itv[i-1];int flg=0,rec=0;
while ((nd[p].d==i)&&(p<=2*n)) {flg=1;rec+=nd[p].u;itv[i]+=nd[p].u;p++;}
if ((!itv[i-1])&&(flg)&&(!rec)) {ans[++cnt].l=i;ans[cnt].r=i;}//对于[i,i]型区间的特判
if ((!(itv[i-1]))&&(itv[i])) ans[++cnt].l=i;
else if ((itv[i-1])&&(!(itv[i]))) ans[cnt].r=i;
}
for (i=1;i<=cnt;++i) printf("%d %d\n",ans[i].l,ans[i].r);
return 0;
}

Luogu_2434_[SDOI2005]区间的更多相关文章

  1. 洛谷——P2434 [SDOI2005]区间

    P2434 [SDOI2005]区间 题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间 ...

  2. 洛谷P2434 [SDOI2005]区间

    题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排列 ...

  3. P2434 [SDOI2005]区间

    题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排列 ...

  4. [SDOI2005]区间

    题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排列 ...

  5. 【洛谷】P2434 [SDOI2005]区间(暴力)

    题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排列 ...

  6. luogu P2434 [SDOI2005]区间

    题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排列 ...

  7. 「LuoguP2434」 [SDOI2005]区间(贪心

    Description 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照 ...

  8. 洛谷 2434 [SDOI2005]区间

    [题解] 鲜活的大水题... 把区间排个序然后瞎搞就可以了,发现现在区间的左端点比之前区间的最大的右端点还大,那就增加一个答案区间.每次更新目前最大右区间. #include<cstdio> ...

  9. 题解 洛谷P2434 【[SDOI2005]区间】

    本题的贪心策略是以区间起点位置由小到大排序,然后开始合并. 区间按起点顺序由小到大排序,可以最大化合并成功的可能. 这个脑补应该不难想出来.(读者自证不难 直接上代码: #include <bi ...

随机推荐

  1. 12 Spring Data JPA:springDataJpa的运行原理以及基本操作(下)

    spring data jpaday1:orm思想和hibernate以及jpa的概述和jpa的基本操作 day2:springdatajpa的运行原理 day2:springdatajpa的基本操作 ...

  2. 寒假day05-spring框架

    1.回顾事务 l 事务:一组业务操作ABCD,要么全部成功,要么全部不成功. l 特性:ACID 原子性:整体 一致性:完成 隔离性:并发 持久性:结果 l 隔离问题: 脏读:一个事务读到另一个事务没 ...

  3. log4j2和logback动态修改日志级别工具类

    工作中,在排查线上问题时,有以下场景在不重新部署或重启服务的情况下,需要动态调整线上日志级别 1.线上有些日志打印过多干扰有用的日志,需要动态修改线上日志记录器的打印日志级别,调高一些日志级别,打印出 ...

  4. python——print函数

    .print()函数概述 print() 方法用于打印输出,是python中最常见的一个函数. 该函数的语法如下: print(*objects, sep=' ', end='\n', file=sy ...

  5. iTOP-3399开发板搭建Android编译坏境

    基于迅为iTOP-3399开发板2.1 装 安装 d android  源码依赖包登录进 Ubuntu 系统,输入“ctrl+alt+t”,打开超级终端,使用“su root”命令,切换到 root ...

  6. 2.监控利器nagios手把手企业级实战第一部

    1.   什么是Nagios?    Nagios是一款开源的网络及服务的监控工具,功能强大,灵活性强,需要注意的是,其服务端只能在linux上面安装.            Nagios可以进行分布 ...

  7. sphinx转pdf显示中文

    在conf.py中 修改, 加入 ctex包 latex_elements = { # The paper size ('letterpaper' or 'a4paper'). #'papersize ...

  8. HTTP编码

    HTTP编码 不仅仅URL需要编码,HTTP header也需要编码,HTTP body 无特殊要求 一般采用百分号编码:比如一个字节的ascii码值是 0x89 那使用百分号编码之后 输出是 %89 ...

  9. Complier

    Complier [2019福建省赛] 模拟题应该有信心写,多出一些样例 当/* 与// 在一起的时候总会出错,一旦出现了这些有效的 应该把它删掉不对后面产生影响 #include<bits/s ...

  10. NLP-文本分类之开始(0)

    转眼读研一年了,开题也开了,方向也定了,大方向就是NLP,然而从一开始的上课.做项目开题什么的(自己也比较贪玩,以前不打游戏,结果王者上瘾了),到现在对NLP是一知半解,不对,半解都没有半解,然后时间 ...