/*
poj2528
  线段树 好题,用到了离散化,二分定位,特殊的区间查寻方式;在下面的代码注释中有详细的解释;
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm> using namespace std;
typedef struct
{
int l,r;
int cnt;//记录该段有几张海报;
int num;//记录该段下面是哪一张海报,0表示没有还海报或海报不唯一;
}Node;
int a[][],n,dot[]={},cou[]={};
Node tr[];
void build(int rt,int l,int r)
{
tr[rt].l=l;
tr[rt].r=r;
tr[rt].cnt=;
tr[rt].num=;
if(l==r)
return ;
int mid=(l+r)/;
build(rt<<,l,mid);
build((rt<<)|,mid+,r);
}
void Pushdown(int rt)
{
tr[rt<<].cnt=;
tr[rt<<|].cnt=;
tr[rt<<].num=tr[rt].num;
tr[rt<<|].num=tr[rt].num;
tr[rt].cnt=;
tr[rt].num=;
}
void Update(int rt,int l,int r,int x)
{
if(tr[rt].l==l&&tr[rt].r==r)
{
tr[rt].cnt=;
tr[rt].num=x;
return;
}
if(tr[rt].cnt==)//当只有一张海报在这个区间的时候才需要pushdown所以可以判断一下;也可以写在pushdown函数里面,我觉得写在外面比较块;
Pushdown(rt);
if(l<=tr[rt<<].r)
{
if(r<=tr[rt<<].r)
Update(rt<<,l,r,x);
else
Update(rt<<,l,tr[rt<<].r,x);
}
if(r>=tr[rt<<|].l)
{
if(l>=tr[rt<<|].l)
Update(rt<<|,l,r,x);
else
Update(rt<<|,tr[rt<<|].l,r,x);
}
if(tr[rt<<].num==tr[rt<<|].num&&tr[rt<<].cnt==&&tr[rt<<|].cnt==)//这以下是pushup的操作,写在这里了;
{
tr[rt].cnt=;
tr[rt].num=tr[rt<<].num;
}
else
tr[rt].cnt=;
}
/*
查询操作比较有趣,因为是查寻区间的海报种类,一个海报可能是首尾可见而中间不可见,所以没办法直接查得,
所以在树的结点上记录的是海报的编号,这样就可以用一个辅助的数组记录哪一个在此次查询中出现过;、
所以每次查询要全区间查询,然后再扫一遍数组;
、每次扫到区间内容一质的时候就不用再扫了;
*/
void Query(int rt)
{
if(tr[rt].cnt==)
{
cou[tr[rt].num]=;
return ;
}
if(tr[rt].l==tr[rt].r)
return ;
if(tr[rt].cnt==)
return ;
Query(rt<<);
Query(rt<<|);
}
int Erfen(int l,int r,int x)//用来确定该点在线段上的位置(离散后的位置);
{
while(l<=r)
{
int mid=(l+r)/;
if(x<dot[mid])
r=mid-;
else
l=mid+;
}
return r;
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
memset(dot,,sizeof(dot));
scanf("%d",&n);
int z=;
for(int i=;i<n;i++)
{
scanf("%d%d",&a[i][],&a[i][]);
dot[z++]=a[i][];
dot[z++]=a[i][];
}
sort(dot,dot+z);//将输入的数据排序后是离散化;因为数据范围比较大,因为只和区间有关,与区间内部的点没有关系,所以只要区间首尾就好;
int t=;
for(int i=;i<z;i++)
{
if(dot[i]!=dot[i-])
dot[t++]=dot[i];
}
for(int i=t-;i>;i--)
{
if(dot[i]-dot[i-]>)
dot[t++]=dot[i-]+;
}
sort(dot,dot+t);
for(int i=t;i>;i--)
dot[i]=dot[i-];
memset(tr,,sizeof(tr));
build(,,t+);
for(int i=;i<=n;i++)
{
int temp1=Erfen(,t,a[i-][]);
int temp2=Erfen(,t,a[i-][]);
Update(,temp1,temp2,i);
}
memset(cou,,sizeof(cou));
Query();
int ans=;
for(int i=;i<=n;i++)
if(cou[i]==)
ans++;
printf("%d\n",ans);
}
return ;
151 }

kb-07专题线段树-04--离散化;的更多相关文章

  1. ACM/ICPC 之 数据结构-线段树+区间离散化(POJ2528)

    这道题用线段树做更方便更新和查询,但是其数据范围很大,因此要将离散化和线段树结合起来,算是一道比较经典的线段树+离散化的例题. 线段树的离散化有很多方法,在这里,我先用一次结点离散化,间接将源左右端点 ...

  2. hdu1542 Atlantis (线段树+扫描线+离散化)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  3. HDU 1542 Atlantis (线段树 + 扫描线 + 离散化)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  4. 【BZOJ-4653】区间 线段树 + 排序 + 离散化

    4653: [Noi2016]区间 Time Limit: 60 Sec  Memory Limit: 256 MBSubmit: 107  Solved: 70[Submit][Status][Di ...

  5. 【BZOJ-4636】蒟蒻的数列 动态开点线段树 ||(离散化) + 标记永久化

    4636: 蒟蒻的数列 Time Limit: 30 Sec  Memory Limit: 256 MBSubmit: 247  Solved: 113[Submit][Status][Discuss ...

  6. HDU 1542 Atlantis(线段树扫描线+离散化求面积的并)

    Atlantis Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  7. [HDOJ5877]Weak Pair(DFS,线段树,离散化)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5877 题意:给一棵树和各点的权值a,求点对(u,v)个数,满足:1.u是v的祖先,2.a(u)*a(v ...

  8. HDU 1255 覆盖的面积 (线段树+扫描线+离散化)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1255 题意很清楚,就是让你求矩阵之间叠加层数大于1的矩形块的面积和. 因为n只有1000,所以我离散化 ...

  9. POJ-1151-Atlantis(线段树+扫描线+离散化)[矩形面积并]

    题意:求矩形面积并 分析:使用线段树+扫描线...因为坐标是浮点数的,因此还需要离散化! 把矩形分成两条边,上边和下边,对横轴建树,然后从下到上扫描上去,用col表示该区间有多少个下边,sum代表该区 ...

  10. poj2299--B - Ultra-QuickSort(线段树,离散化)

    Ultra-QuickSort Time Limit: 7000MS   Memory Limit: 65536K Total Submissions: 41215   Accepted: 14915 ...

随机推荐

  1. 文件 MD5 SHA1 SHA256 SHA512 校验码生成工具 V1.3

    [程序介绍]免费开源的 文件 MD5 SHA1 SHA256 SHA512 校验码生成工具 V1.3 这是一个有意思的程序,同一个程序,即是图形程序,又是命令行程序.程序作用:输入一个文件的路径,输出 ...

  2. iperf安装与使用

    从官网下载相应版本. https://iperf.fr/iperf-download.php centos7 安装 rpm -i iperf3-3.1.3-1.fc24.x86_64.rpm ubun ...

  3. String中关于BeanFactory

    org.springframework.beans及org.springframework.context包是Spring IoC容器的基础.BeanFactory提供的高级配置机制,使得管理任何性质 ...

  4. linux关于任务计划

    1.一次性任务计划:at 1)添加 在18:16时候重启服务器 at 18:16 >at init 6 >at ctrl+d2)查看 atq 1 Mon Aug 20 21:09:00 2 ...

  5. 示例vue 的keep-alive缓存功能的实现

    本篇文章主要介绍了vue 的keep-alive缓存功能的实现,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下.如有不足之处,欢迎批评指正. Vue 实现组件信息的缓存 当我们 ...

  6. 能力不足之 根据时序图转化为Verilog代码

    不能够把时序图看的非常透彻,然后把时序图写成Verilog代码,有时候甚至搞不清楚信号之间的时序关系.

  7. Redis的安装、服务配置

    在网上找了很多资料,有些可以正常安装,有些安装会出毛病,仔细想了想,还是自己整理一份吧,仅仅为自己下次再用的时候,能够快速的定位到可以正常用的文章! 我使用的是VMware Workstation P ...

  8. Python中的列表(1)

    1.什么是列表? 列表是由一组按特定顺序排列的元素组成. 2.如何表示? 在Python中用方括号([ ])来表示列表.栗子如下: contries = ['China','England','Fra ...

  9. Word 借助VBA一键实现插入交叉引用

    最近写论文的时候,经常需要向上或向下插入题注的交叉引用,word 自带的界面往往需要操作多次,才能实现插入.而平时使用较多的只是交叉引用附近的题注,比如如图1.1所示,在图1.1中等,距离较远的引用则 ...

  10. ProC第一弹

    编译pro*c 的makefile例子 原来只需在makefile中追加include $(ORACLE_HOME)/precomp/lib/env_precomp.mk,其他一切按照makefile ...