【线段树+离散化】POJ2528-Mayor's posters
【题目大意】
在墙上贴海报,问最后能看到几张海报?
【注意点】
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的更多相关文章
- Mayor's posters(线段树+离散化POJ2528)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 51175 Accepted: 14820 Des ...
- 线段树---poj2528 Mayor’s posters【成段替换|离散化】
poj2528 Mayor's posters 题意:在墙上贴海报,海报可以互相覆盖,问最后可以看见几张海报 思路:这题数据范围很大,直接搞超时+超内存,需要离散化: 离散化简单的来说就是只取我们需要 ...
- poj-----(2528)Mayor's posters(线段树区间更新及区间统计+离散化)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 43507 Accepted: 12693 ...
- [POJ2528]Mayor's posters(离散化+线段树)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 70365 Accepted: 20306 ...
- [poj2528] Mayor's posters (线段树+离散化)
线段树 + 离散化 Description The citizens of Bytetown, AB, could not stand that the candidates in the mayor ...
- POJ 2528 Mayor's posters(线段树+离散化)
Mayor's posters 转载自:http://blog.csdn.net/winddreams/article/details/38443761 [题目链接]Mayor's posters [ ...
- poj 2528 Mayor's posters(线段树+离散化)
/* poj 2528 Mayor's posters 线段树 + 离散化 离散化的理解: 给你一系列的正整数, 例如 1, 4 , 100, 1000000000, 如果利用线段树求解的话,很明显 ...
- poj 2528 Mayor's posters 线段树+离散化技巧
poj 2528 Mayor's posters 题目链接: http://poj.org/problem?id=2528 思路: 线段树+离散化技巧(这里的离散化需要注意一下啊,题目数据弱看不出来) ...
- Mayor's posters (线段树+离散化)
Mayor's posters Description The citizens of Bytetown, AB, could not stand that the candidates in the ...
随机推荐
- 创建Fragment和传递数值
下面在扩展一下创建Fragment和传递数值 如果我们不需要传递数值,那就直接可以在宿主activity中,跟平常一样创建fragment,但是如果我们需要传递数据的话,可以使用newInstance ...
- [一] sqlinject bypass
http://103.238.227.13:10087/?id=1 由源码来看是没有办法注入的,几乎都是过滤了的.但是经过测试加<>符号会被直接替换为空. 那么就可以借助此进行bypass ...
- WoW[www]
WoWBeez https://github.com/StealtheeEU/WoWBeez https://github.com/mtucker6784/Elysium https://github ...
- tornado当用户输入的URL无效时转入设定的页面
今天做web的测验..坑爹的要用tornado...作为一个比较新的用的人还不多的东东...查资料好麻烦.. 下面是当用户输入非法 url时, 显示一个自定义 404 页面提示用户,其访问的页面不存在 ...
- 【数位dp入门】【HDU2089】62
为了我的点歪的技能树…… 所以开始补一些sb的东西…… #include<bits/stdc++.h> typedef long long ll; using namespace std; ...
- uoj#35 后缀排序(后缀数组模版)
#include<bits/stdc++.h> #define N 100005 using namespace std; char s[N]; int a[N],c[N],t1[N],t ...
- SQL中判断值是否为NULL
在 SQL 中,我们如果在操作数据库时使用 WHERE 子句判断一个列的值是否为 NULL,我们不能够使用 column_name=null 来进行判断,这是不正确的,我们应该使用 is null 来 ...
- leetcode 之Gas Station(11)
这题的思路很巧妙,用两个变量,一个变量衡量当前指针是否有效,一个衡量整个数组是否有解,需要好好体会. int gasStation(vector<int> &gas, vector ...
- 18:django 日志系统
django使用python内建的logging模块去建造自己的系统日志的,如果你想详细了解这个模块的话,请自己去看python的说明文档,这里仅仅介绍django中的日志系统 日志配置包括四个部分: ...
- pom报错解决方法大全
1.Failure to transfer org.apache.maven.plugins:maven-surefire-plugin:pom 解决方法: Windows: CMD --> c ...