POJ2528Mayor's posters[线段树 离散化]
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 59683 | Accepted: 17296 |
Description
- Every candidate can place exactly one poster on the wall.
- All posters are of the same height equal to the height of the wall; the width of a poster can be any integer number of bytes (byte is the unit of length in Bytetown).
- The wall is divided into segments and the width of each segment is one byte.
- Each poster must completely cover a contiguous number of wall segments.
They have built a wall 10000000 bytes long (such that there is enough place for all candidates). When the electoral campaign was restarted, the candidates were placing their posters on the wall and their posters differed widely in width. Moreover, the candidates started placing their posters on wall segments already occupied by other posters. Everyone in Bytetown was curious whose posters will be visible (entirely or in part) on the last day before elections.
Your task is to find the number of visible posters when all the posters are placed given the information about posters' size, their place and order of placement on the electoral wall.
Input
Output
The picture below illustrates the case of the sample input. 
Sample Input
1
5
1 4
2 6
8 10
3 4
7 10
Sample Output
4
Source
notonlysuccess大神的题解
题意:在墙上贴海报,海报可以互相覆盖,问最后可以看见几张海报 思路:这题数据范围很大,直接搞超时+超内存,需要离散化: 离散化简单的来说就是只取我们需要的值来用,比如说区间[,],[,] 我们用不到[-∞,][,][,][,][,+∞]这些值,所以我只需要1000,,,2012就够了,将其分别映射到0,,,,在于复杂度就大大的降下来了 所以离散化要保存所有需要用到的值,排序后,分别映射到1~n,这样复杂度就会小很多很多 而这题的难点在于每个数字其实表示的是一个单位长度(并且一个点),这样普通的离散化会造成许多错误(包括我以前的代码,poj这题数据奇弱) 给出下面两个简单的例子应该能体现普通离散化的缺陷: - - - - - - 为了解决这种缺陷,我们可以在排序后的数组上加些处理,比如说[,,,] 如果相邻数字间距大于1的话,在其中加上任意一个数字,比如加成[,,,,,],然后再做线段树就好了. 线段树功能:update:成段替换 query:简单hash
说一下离散化,用map完美TLE,改成1e7大数组因为memset太耗时,再改成二分搜索用下标快好多
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <map>
using namespace std;
const int N=1e4+,TREE=4e4+;
#define m (l+r)/2
#define lson o<<1,l,m
#define rson o<<1|1,m+1,r
#define lc o<<1
#define rc o<<1|1
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
}
//map<int,int> mp;
//int mp[10000009];
int mp[N<<];
int t[TREE<<];
int T,n,ll[N],rr[N],a[N<<];
inline void paint(int o,int v){
t[o]=v;
}
inline void pushDown(int o){
if(t[o]!=){
paint(lc,t[o]);
paint(rc,t[o]);
t[o]=;
}
}
void draw(int o,int l,int r,int ql,int qr,int v){//printf("draw %d %d %d\n",o,l,r);
if(ql<=l&&r<=qr) paint(o,v);
else{
pushDown(o);
if(ql<=m) draw(lson,ql,qr,v);
if(m<qr) draw(rson,ql,qr,v);
}
}
int vis[N],ans=;
void query(int o,int l,int r,int ql,int qr){//printf("quer %d %d %d\n",o,l,r);
if(t[o]){
if(!vis[t[o]]){ans++;vis[t[o]]=;}
}else{
if(l==r) return;
if(ql<=m) query(lson,ql,qr);
if(m<qr) query(rson,ql,qr);
}
}
int main(){
T=read();
while(T--){
n=read();
memset(t,,sizeof(t));
//mp.clear();
//memset(mp,0,sizeof(mp));
for(int i=;i<=n;i++){ll[i]=read();rr[i]=read();a[*i-]=ll[i];a[*i]=rr[i];}
sort(a+,a++*n);
int cnt=;
// mp[a[1]]=++cnt;
// for(int i=2;i<=2*n;i++)
// if(a[i]!=a[i-1]){
// //if(!mp.count(a[i]-1)) mp[a[i]-1]=++cnt;
// if(!mp[a[i]-1]) mp[a[i]-1]=++cnt;
// mp[a[i]]=++cnt;
// }
// for(int i=1;i<=n;i++){
// int ql=mp[ll[i]],qr=mp[rr[i]];//printf("hi %d %d\n",ql,qr);
// draw(1,1,cnt,ql,qr,i);
// }
//
for(int i=;i<=*n;i++) if(a[i]!=a[i-]) mp[++cnt]=a[i];
for(int i=cnt;i>=;i--) if(mp[i]!=mp[i-]+) mp[++cnt]=mp[i-]+;
sort(mp+,mp++cnt);
for(int i=;i<=n;i++){
int ql=lower_bound(mp+,mp++cnt,ll[i])-mp,qr=lower_bound(mp+,mp++cnt,rr[i])-mp;
draw(,,cnt,ql,qr,i);
}
ans=;
memset(vis,,sizeof(vis));
query(,,cnt,,cnt);
printf("%d\n",ans); //printf("\n\ncnt %d\n",cnt);
//for(int i=1;i<=10;i++) printf("mp %d %d\n",i,mp[i]);
}
}
POJ2528Mayor's posters[线段树 离散化]的更多相关文章
- POJ 2528 Mayor's posters(线段树+离散化)
Mayor's posters 转载自:http://blog.csdn.net/winddreams/article/details/38443761 [题目链接]Mayor's posters [ ...
- [poj2528] Mayor's posters (线段树+离散化)
线段树 + 离散化 Description The citizens of Bytetown, AB, could not stand that the candidates in the mayor ...
- 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 ...
- POJ2528Mayor's posters 线段树,离散化技巧
题意:一个坐标轴从1~1e7,每次覆盖一个区间(li,ri),问最后可见区间有多少个(没有被其他区间挡住的) 线段树,按倒序考虑,贴上的地方记为1,每次看(li,ri)这个区间是否全是1,全是1就说明 ...
- Mayor's posters(线段树+离散化POJ2528)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 51175 Accepted: 14820 Des ...
- POJ 2528 Mayor's posters (线段树+离散化)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions:75394 Accepted: 21747 ...
- poj 2528 Mayor's posters 线段树+离散化 || hihocode #1079 离散化
Mayor's posters Description The citizens of Bytetown, AB, could not stand that the candidates in the ...
- poj 2528 Mayor's posters(线段树+离散化)
/* poj 2528 Mayor's posters 线段树 + 离散化 离散化的理解: 给你一系列的正整数, 例如 1, 4 , 100, 1000000000, 如果利用线段树求解的话,很明显 ...
随机推荐
- ComponentOne 2016 V2发布了!
火热的夏季迎了ComponentOne今年的第2个重大发布.这次发布包含了一些非常棒的新控件以及很多大的功能增强. 快来下载免费试用版体验吧! FlexChart(UWP.WPF.WinForms ...
- 向 div 元素添加圆角边框:
div { border:2px solid; border-radius:25px; }
- LNMP环境搭建完整步骤
零.resource http://pan.baidu.com/s/1o83r3S2 一.centos 6.4.VirtualBox 5.0.14 二.nginx 1.9.9 安装 [root@p ...
- ElasticSearch+NLog+Elmah实现Asp.Net分布式日志管理
本文将介绍使用NLOG.Elmah结合ElasticSearch实现分布式日志管理. 一.ElasticSearch简介 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布 ...
- PHP 根据key 给二维数组分组
我们经常拿到一个二维数组出来,会发现结果和自己想要的有些偏差,可能需要根据二维数组里的某个字段对数组分组.先来看以下数组, Array ( [0] => Array ( [id] => 1 ...
- [连载]《C#通讯(串口和网络)框架的设计与实现》-4.设备驱动管理器的设计
目 录 第四章 设备驱动管理器的设计... 2 4.1 接口定义... 2 4.2 设备容器... 7 4.3 ...
- 推荐15款创建漂亮幻灯片的 jQuery 插件
对于设计师,开发者,摄影师或任何创造性的个人和企业,他们自己的网站是展示他们的技能和服务的最佳场所.你可能打算设计一个新的个人作品网站,不管你是从头开始或使用模板,都会需要使用 jQuery 幻灯片插 ...
- jquery自定义对话框alert、confirm和prompt
jQuery Alert Dialogs,又一个基于jQuery的提示框插件,主要包括Alert.Confirm.prompt这三种,还有一个高级范例,可以在提示框内嵌入HTML语言,可以自定义风格样 ...
- JS实现自适应宽度的Tag切换
效果体验:http://hovertree.com/texiao/js/3.htm 该效果使用纯JavaScript代码,实现TAB页切换效果,TAB标签根据内容自适应宽度,点击TAB标签切换内容页. ...
- js for循环中i++ 和 ++i有什么区别?
平时都是这样写的for循环, for(var i = 0; i < 20 ; i++){ .... } 但我看有的人这样写 for (var i = 0; i < 20 ; ++i) { ...