洛谷——P2434 [SDOI2005]区间
P2434 [SDOI2005]区间
题目描述
现给定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]。
输出格式:
输出计算出来的不相交的区间。每一行都是对一个区间的描述,包括两个用空格分开的整数,为区间的上下界。你应该把区间按照升序排序。
输入输出样例
5 5 6 1 4 10 10 6 9 8 10
1 4 5 10
思路:先使用很基础的操作,也就是线段覆盖的方式,将每一条线段插入线段树。最后求区间的做法是这样子的:
设两个变量a,b。一开始都让他们等于1.开个while(b<=n);每次查询区间【a,b】是否被完全覆盖。是的话,b++;不是的话判断a是否等于b,如果等于。a++,b++;如果a不等于b那么输出a b;然后a=b。
最后跳出循环时也要判断a是否等于b,等于的话程序结束。不等于的话输出a b,其实也就是a n。程序结束
注意一个地方!
我们在进行修改的时候修改的是一段区间,但是我们线段树中的这段区间与我们所说的区间有一点不一样,例如样例中的1~4,5~6,我们如果用线段树进行修改的话我们修改出来的会是
1 1 1 1 1 1 也就是说我们将1~6整个区间都给修改了,但是我们所说的修改是要将其变成1 1 1 0 1 1 也就是说4这个点不进行修改。那么我们在修改的时候就讲尾节点-1以后再进行区间修改就好了。
代码:
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 410000
using namespace std;
int n,m,x,y,xx[N],yy[N],ans,sum;
int read()
{
,f=; char ch=getchar();
; ch=getchar();}
+ch-'; ch=getchar();}
return x*f;
}
struct Tree
{
int l,r,w,f;
}tree[N];
void build(int k,int l,int r)
{
tree[k].l=l,tree[k].r=r;
if(tree[k].l==tree[k].r)
{
tree[k].w=;
return ;
}
;
build(k<<,l,m);
build(k<<|,m+,r);
}
int down(int k)
{
tree[k<<].f=tree[k].f;
tree[k<<|].f=tree[k].f;
tree[k<<].w=tree[k<<].r-tree[k<<].l+;
tree[k<<|].w=tree[k<<|].r-tree[k<<|].l+;
tree[k].f=;
}
void change_interval(int k)
{
if(tree[k].l>=x&&tree[k].r<=y)
{
tree[k].w=tree[k].r-tree[k].l+;
tree[k].f=;
return;
}
if(tree[k].f) down(k);
;
);
|);
tree[k].w=tree[k<<].w+tree[k<<|].w;
}
void ask_interval(int k)
{
if(tree[k].l>=x&&tree[k].r<=y)
{
ans+=tree[k].w;
return;
}
if(tree[k].f) down(k);
;
);
|);
}
int main()
{
n=read();
;i<=n;i++)
xx[i]=read(),yy[i]=read(),m=max(m,max(xx[i],yy[i]));
build(,,m);
;i<=n;i++)
x=xx[i],y=yy[i]-,change_interval();
x=,y=;
while(y<=m)
{
ans=;ask_interval();
) y++;
else
{
if(x==y) x++,y++;
else
{
printf("%d %d\n",x,y);
x=y;
}
}
}
if(x!=y) printf("%d %d",x,m);
;
}
原来是打算用来练线段树的一道题,结果做了一下午,而且这道题暴力,贪心,前缀和都可以做!!!!
唉,发一个贪心的吧、、、按左端点排序后,记录当前区间[L,R],如果新的区间的l<=R,说明新的区间可以合并,更新R,如果新的区间l>R,说明新的区间不能跟当前区间合并,又因为已经按左端点拍了序,所以输出当前区间。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 410000
using namespace std;
int n,m,x,y,ans,sum;
int read()
{
,f=; char ch=getchar();
; ch=getchar();}
+ch-'; ch=getchar();}
return x*f;
}
struct A
{
int l,r;
}a[N];
int cmp(A a,A b)
{
return a.l<b.l;
}
int main()
{
n=read();
;i<=n;i++)
a[i].l=read(),a[i].r=read();
sort(a+,a++n,cmp);
].l,r=a[].r;
;i<=n;i++)
{
if(a[i].l<=r) r=max(r,a[i].r);
else
{
printf("%d %d\n",l,r);
l=a[i].l;r=a[i].r;
}
}
printf("%d %d",l,r);
;
}
洛谷——P2434 [SDOI2005]区间的更多相关文章
- 洛谷P2434 [SDOI2005]区间
题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排列 ...
- 洛谷 2434 [SDOI2005]区间
[题解] 鲜活的大水题... 把区间排个序然后瞎搞就可以了,发现现在区间的左端点比之前区间的最大的右端点还大,那就增加一个答案区间.每次更新目前最大右区间. #include<cstdio> ...
- 洛谷 1063 dp 区间dp
洛谷 1063 dp 区间dp 感觉做完这道提高组T1的题之后,受到了深深的碾压,,最近各种不在状态.. 初看这道题,不难发现它具有区间可并性,即(i, j)的最大值可以由(i, k) 与 (k+1, ...
- BZOJ5259/洛谷P4747: [Cerc2017]区间
BZOJ5259/洛谷P4747: [Cerc2017]区间 2019.8.5 [HZOI]NOIP模拟测试13 C.优美序列 思维好题,然而当成NOIP模拟题↑真的好吗... 洛谷和BZOJ都有,就 ...
- 洛谷P1712 [NOI2016]区间 尺取法+线段树+离散化
洛谷P1712 [NOI2016]区间 noi2016第一题(大概是签到题吧,可我还是不会) 链接在这里 题面可以看链接: 先看题意 这么大的l,r,先来个离散化 很容易,我们可以想到一个结论 假设一 ...
- 【洛谷】P2434 [SDOI2005]区间(暴力)
题目描述 现给定n个闭区间[ai, bi],1<=i<=n.这些区间的并可以表示为一些不相交的闭区间的并.你的任务就是在这些表示方式中找出包含最少区间的方案.你的输出应该按照区间的升序排列 ...
- 洛谷 P1890 gcd区间
P1890 gcd区间 题目提供者 洛谷OnlineJudge 标签 数论(数学相关) 难度 普及/提高- 题目描述 给定一行n个正整数a[1]..a[n]. m次询问,每次询问给定一个区间[L,R] ...
- 洛谷P2879 [USACO07JAN]区间统计Tallest Cow
To 洛谷.2879 区间统计 题目描述 FJ's N (1 ≤ N ≤ 10,000) cows conveniently indexed 1..N are standing in a line. ...
- 题解 洛谷P2434 【[SDOI2005]区间】
本题的贪心策略是以区间起点位置由小到大排序,然后开始合并. 区间按起点顺序由小到大排序,可以最大化合并成功的可能. 这个脑补应该不难想出来.(读者自证不难 直接上代码: #include <bi ...
随机推荐
- 深入理解Java的整型类型:如何实现2+2=5?
先看下这段神奇的Java代码: public static void main(String[] args) throws Exception { doSomethingMagic(); System ...
- 使用正则进行HTML页面属性的替换
使用正则表达式拼接富文本框 package com.goboosoft.common.utils; import org.apache.commons.lang3.StringUtils; impor ...
- centos下安装nodejs的三种种方式
方法一:源码包安装 官网下载 centos下载最新版10.9 https://nodejs.org/dist/v10.9.0/node-v10.9.0-linux-x64.tar.xz mkdir / ...
- 为什么我的 app:actionViewClass="android.widget.SearchView"和app:showAsAction="ifRoom|collapseActionView"才有
http://blog.csdn.net/cdnight/article/details/48029911 <item android:id="@+id/action_search&q ...
- github 从一个仓库换到另一个仓库
1.找到.git目录 2.打开config文件 3.修改仓库地址 4.重新提交 git push --all origin 这样就替我们的项目换仓啦!!!^_^
- 小程序02 wxml和wxss
微信小程序的排版就跟wxml和wxss有关,它们两者相当于HTML和CSS,其中wxml指定了界面的框架结构,而wxss指定了界面的框架及元素的显示样式. 一.wxml 界面结构wxmL比较容易理解, ...
- Hibernate的持久化对象配置
定义Pojo对象和**.hbm.xml文件 -1 对于每一个需要持久化的对象都需要创建一个Pojo类定义,Hibernate要求POJO类定义中必须有一个no-argument的构造方法,便于Hibe ...
- java 生成二维码工具
二维码生成 Gitee:https://gitee.com/search?utf8=%E2%9C%93&search=qrext4j&group_id=&project_id= ...
- (1) openssl基础概念
1.1 背景知识 对称加密 :加密解密使用同一密钥,加解密速度快.随着人数增多,密钥数量急增n(n-1)/2. 非对称加密 :使用公私钥配对加解密,速度慢.公钥是从私钥中提取出来的,一般拿对方 ...
- LeetCode(27)Remove Element
题目 Given an array and a value, remove all instances of that value in place and return the new length ...