POJ2528 线段树的区间操作
首先应该对该【0,10000000】进行离散化
即先将点集进行排序,然后从小到大缩小其中的间距,使得最后点数不会超过2*n
然后就是线段树操作
只需进行染色,然后最后用nlgn进行一个个查询颜色记录即可
#include<cstdio>
#include<cstring>
int color[20005*4],a[20005],p[20005],l[10005],r[10005],pd[10005],i,j,k,n,t,length;
void qs(int x,int y){
int i=x,j=y,k=a[(x+y)/2],t;
do{
while(a[i]<k) i++;
while(a[j]>k) j--;
if(i<=j){
t=a[i];a[i]=a[j];a[j]=t;
t=p[i];p[i]=p[j];p[j]=t;
i++;j--;
}
}while(i<j);
if(i<y) qs(i,y);
if(x<j) qs(x,j);
}
void build(int x,int y,int rt){
color[rt]=0;
if(x>=y) return;
int m=(x+y)/2;
build(x,m,2*rt);
build(m+1,y,2*rt+1);
}
void PushDown(int rt){
if(color[rt]!=0){
color[rt*2]=color[rt*2+1]=color[rt];
color[rt]=0;
}
}
void update(int x,int y,int rt){
if(l[k]<=x&&r[k]>=y){
color[rt]=k;
return;
}
PushDown(rt);
int m=(x+y)/2;
if(l[k]<=m) update(x,m,rt*2);
if(r[k]>m) update(m+1,y,rt*2+1);
}
int query(int x,int y,int rt){
if(color[rt]!=0){
if(!pd[color[rt]]) {
pd[color[rt]]=1;
return 1;
}
else return 0;
}
if(x==y) return 0;
int m=(x+y)/2;
return(query(x,m,rt*2)+query(m+1,y,rt*2+1));
}
int main()
{
scanf("%d",&t);
while(t--){
memset(pd,0,sizeof(pd));
scanf("%d",&n);
for(i=1;i<=n;i++){
scanf("%d%d",&a[2*i-1],&a[2*i]);
p[2*i-1]=2*i-1;
p[2*i]=2*i;
}
qs(1,2*n);
length=1;
for(i=1;i<=2*n;i++){
if(p[i]%2==0)
r[p[i]/2]=length;
else
l[(p[i]+1)/2]=length;
if(a[i]!=a[i+1]) length++;
}
build(1,length,1);
for(k=1;k<=n;k++)
update(1,length,1);
printf("%d\n",query(1,length,1));
}
return 0;
}
POJ2528 线段树的区间操作的更多相关文章
- poj-2528线段树练习
title: poj-2528线段树练习 date: 2018-10-13 13:45:09 tags: acm 刷题 categories: ACM-线段树 概述 这道题坑了我好久啊啊啊啊,,,, ...
- Codeforces Round #222 (Div. 1) D. Developing Game 线段树有效区间合并
D. Developing Game Pavel is going to make a game of his dream. However, he knows that he can't mak ...
- hiho一下20周 线段树的区间修改
线段树的区间修改 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题改了改,又出给了 ...
- hihoCode 1078 : 线段树的区间修改
#1078 : 线段树的区间修改 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题 ...
- UVA 12436-Rip Van Winkle's Code(线段树的区间更新)
题意: long long data[250001]; void A( int st, int nd ) { for( int i = st; i \le nd; i++ ) data[i] = da ...
- BZOJ 3110 ZJOI 2013 K大数查询 树套树(权值线段树套区间线段树)
题目大意:有一些位置.这些位置上能够放若干个数字. 如今有两种操作. 1.在区间l到r上加入一个数字x 2.求出l到r上的第k大的数字是什么 思路:这样的题一看就是树套树,关键是怎么套,怎么写.(话说 ...
- hihoCoder #1078 : 线段树的区间修改(线段树区间更新板子题)
#1078 : 线段树的区间修改 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题 ...
- 线段树(区间树)之区间染色和4n推导过程
前言 线段树(区间树)是什么呢?有了二叉树.二分搜索树,线段树又是干什么的呢?最经典的线段树问题:区间染色:正如它的名字而言,主要解决区间的问题 一.线段树说明 1.什么是线段树? 线段树首先是二叉树 ...
- HDU 1698 just a hook 线段树,区间定值,求和
Just a Hook Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1 ...
随机推荐
- RHEL 7.2 安装Oracle XE-11.2.0
轻量快捷版本,适合开发 0. /etc/hosts 添加 本机hostname # hostnamepromote.cache-dns.local # cat /etc/hosts127.0.0.1 ...
- php array_walk 和 array_reduce函数
1.array_walk:将数组中的元素(键+值)依次取出传给处理的函数,函数处理完就完了,没有返回值. $arr1=array( 'name'=>'zhangsan', 'age'=>3 ...
- Pl/sql 导入数据错位问题
在查询列的时候 多查询一列就可以了 当然是要在所有列对应的情况下 把第一列的 前追加一列 这样就不会错位了 例如如下图
- Hibernate从入门到精通(六)一对一双向关联映射
在上次的博文Hibernate从入门到精通(五)一对一单向关联映射中我们讲解了一下一对一单向关联映射,这次我们继续讲解一下与之对应的一对一双向关联映射. 一对一双向关联 与一对一单向关联映射所不同的的 ...
- chm文件打开,有目录没有内容
下载下来的一些chm文件,打开的是否提示“打开此文件前总是询问”,不理睬直接打开后,只有目录,页面内容都显示“已取消到本页的导航”.原因是该CHM文件的发行商未知,将“打开此文件前总是询问”选项取消后 ...
- php实现调用微信上传照片然后保存至服务器与数据库
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script> <s ...
- [百度]数组A中任意两个相邻元素大小相差1,在其中查找某个数
一.问题来源及描述 今天看了July的微博,发现了七月问题,有这个题,挺有意思的. 数组A中任意两个相邻元素大小相差1,现给定这样的数组A和目标整数t,找出t在数组A中的位置.如数组:[1,2,3,4 ...
- EasyUI datagrid 分页Json字符串格式
//EasyUI datagrid 分页Json字符串格式 //{"total":xx,"rows":[{...},{...}]} total:总数 rows: ...
- PAT-乙级-1045. 快速排序(25)
1045. 快速排序(25) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 著名的快速排序算法里有一个经典的划分 ...
- Chp2: Linked List
2.2 Implement an algorithm to find the kth to last element of a singly linked list. Just using " ...