【题目大意】

在墙上贴海报,问最后能看到几张海报?

【注意点】

1.首先要注意这是段线段树,而非点线段树。读题的时候注意观察图。来看discuss区下面这组数据:

3

5 6

4 5

6 8

上面数据的答案应该是2,注意观察图,覆盖的是区间。

2.离散化

由于覆盖的是区间,不能简单的离散化,否则会出现差错。比如说下面这组数据:

1 5

1 3

4 5

以及

1 5

1 2

4 5

如果简单离散化都会变成:

1 4

1 2

3 4

最后得出只能看到两张海报的结论,而事实上第一组数据中能够看到三张海报,为了解决这个问题,如果相邻两个数之间相差大于1,就补上一个中间的数字。

比如说1 4,离散化成为1 2 3

3.数据范围:线段树要开到<<4,至于为什么还没有研究出来。X要开到三倍,因为不仅要考虑左右边界均放进来,而且还要考虑中间增添上来离散化的数字。

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
/*define后面绝对不能加分号*/
using namespace std;
const int MAXN=+;
int l[MAXN],r[MAXN];
int X[MAXN*],t,M;
int col[MAXN<<];
int hash[MAXN];
/*延迟标记当前区域被编号为几的覆盖*/
int ans; void pushdown(int rt)
{
if (col[rt]!=-)
{
col[rt<<]=col[rt];
col[rt<<|]=col[rt];
col[rt]=-;
}
} int Bin(int key)
{
int ub=,lb=M+;
while (lb>ub)
{
int m=(ub+lb)/;
if (X[m]==key) return m;
if (X[m]>key) lb=m;
else (ub=m);
}
return -;
} void update(int L,int R,int l,int r,int rt,int cit)
{
if (L<=l && r<=R)
{
col[rt]=cit;
return;
}
pushdown(rt);
int m=(l+r)>>;
if (L <= m) update(L,R,lson,cit);
if (m < R) update(L,R,rson,cit);
} void query(int l,int r,int rt)
{
if (col[rt]!=-)
{
if (hash[col[rt]]!=) ans++;
hash[col[rt]]=;
return;
}
if (l==r) return;
int m=(l+r)>>;
query(lson);
query(rson);
} void init()
/*输入数据并进行离散化*/
{
int num=;
scanf("%d",&t);
for (int i=;i<t;i++)
{
scanf("%d%d",&l[i],&r[i]);
X[++num]=l[i];
X[++num]=r[i];
}
sort(X+,X+num+);
/*M来记录离散化之后总共出现了几个数字*/
M=;
/*注意因为下面的for循环是从2开始的,所以m的初始值要是1,否则第一个数字会被覆盖掉*/
for (int i=;i<=num;i++)
{
if (X[i]!=X[i-]) X[++M]=X[i];
/*重复的数字只记录一次*/
}
num=M;
for (int i=;i<=num;i++)
{
if (X[i]-X[i-]>) X[++M]=X[i]-;
/*离散化时要注意,如果两个点相差大于1,则在中间再插入一个数字*/
}
sort(X+,X+M+);
} void submain()
{
memset(col,-,sizeof(col));
for (int i=;i<t;i++)
{
int lp=Bin(l[i]);
int rp=Bin(r[i]);
update(lp,rp,,M,,i);
/*二分查找左边界和右边界离散化后对应的数值*/
}
} int main()
{
int T;
scanf("%d",&T);
for (int kase=;kase<T;kase++)
{
init();
submain();
ans=;
memset(hash,,sizeof(hash));
query(,M,);
cout<<ans<<endl;
}
return ;
}

【线段树+离散化】POJ2528-Mayor's posters的更多相关文章

  1. Mayor's posters(线段树+离散化POJ2528)

    Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 51175 Accepted: 14820 Des ...

  2. 线段树---poj2528 Mayor’s posters【成段替换|离散化】

    poj2528 Mayor's posters 题意:在墙上贴海报,海报可以互相覆盖,问最后可以看见几张海报 思路:这题数据范围很大,直接搞超时+超内存,需要离散化: 离散化简单的来说就是只取我们需要 ...

  3. poj-----(2528)Mayor's posters(线段树区间更新及区间统计+离散化)

    Mayor's posters Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 43507   Accepted: 12693 ...

  4. [POJ2528]Mayor's posters(离散化+线段树)

    Mayor's posters Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 70365   Accepted: 20306 ...

  5. [poj2528] Mayor's posters (线段树+离散化)

    线段树 + 离散化 Description The citizens of Bytetown, AB, could not stand that the candidates in the mayor ...

  6. POJ 2528 Mayor's posters(线段树+离散化)

    Mayor's posters 转载自:http://blog.csdn.net/winddreams/article/details/38443761 [题目链接]Mayor's posters [ ...

  7. poj 2528 Mayor's posters(线段树+离散化)

    /* poj 2528 Mayor's posters 线段树 + 离散化 离散化的理解: 给你一系列的正整数, 例如 1, 4 , 100, 1000000000, 如果利用线段树求解的话,很明显 ...

  8. poj 2528 Mayor's posters 线段树+离散化技巧

    poj 2528 Mayor's posters 题目链接: http://poj.org/problem?id=2528 思路: 线段树+离散化技巧(这里的离散化需要注意一下啊,题目数据弱看不出来) ...

  9. Mayor's posters (线段树+离散化)

    Mayor's posters Description The citizens of Bytetown, AB, could not stand that the candidates in the ...

随机推荐

  1. bzoj 2809 左偏树\平衡树启发式合并

    首先我们对于一颗树,要选取最多的节点使得代价和不超过m,那么我们可以对于每一个节点维护一个平衡树,平衡树维护代价以及代价的和,那么我们可以在logn的时间内求出这个子树最多选取的节点数,然后对于一个节 ...

  2. 对象方法、类方法、原型方法 && 私有属性、公有属性、公有静态属性

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  3. hdfs文件上传机制与namenode元数据管理机制

    1.hdfs文件上传机制 文件上传过程:   1.客户端想NameNode申请上传文件, 2.NameNode返回此次上传的分配DataNode情况给客户端 3.客户端开始依向dataName上传对应 ...

  4. 【Python学习笔记】Coursera课程《Using Python to Access Web Data 》 密歇根大学 Charles Severance——Week2 Regular Expressions课堂笔记

    Coursera课程<Using Python to Access Web Data > 密歇根大学 Charles Severance Week2 Regular Expressions ...

  5. Java基础 变量和数据类型及相关操作

    Java基本语法: 1):Java语言严格区分大小写,好比main和Main是完全不同的概念. 2):一个Java源文件里可以定义多个Java类,但其中最多只能有一个类被定义成public类.若源文件 ...

  6. python基础===Excel处理库openpyxl

    openpyxl是一个第三方库,可以处理xlsx格式的Excel文件. 安装: pip install openpyxl 对如下excel进行读取操作,如图: from openpyxl import ...

  7. MNIST数据集转化为二维图片

    #coding: utf-8 from tensorflow.examples.tutorials.mnist import input_data import scipy.misc import o ...

  8. App推广

    一行业常见名词解释 开发商:也叫CP,即Content Provider内容提供商的英文首字母缩写. 发行商(运营商):即代理CP开发出来的产品. 渠道:拥有用户,能够进行流量分发的公司,即可成为渠道 ...

  9. laravel 中的入口文件报错

    1.此次是由于加载的配置文件的编码错误导致的.例:conf.php

  10. windows系统安装mysql压缩zip版

    1.下载 打开官网:https://www.mysql.com 进入DOWNLOADS--->Community--->MySQL Community Server,选择系统对应的版本点击 ...