poj2528 Mayor's posters【线段树】
The citizens of Bytetown, AB, could not stand that the candidates in the mayoral election campaign have been placing their electoral posters at all places at their whim. The city council has finally decided to build an electoral wall for placing the posters and introduce the following rules:
- 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
The first line of input contains a number c giving the number of cases that follow. The first line of data for a single case contains number 1 <= n <= 10000. The subsequent n lines describe the posters in the order in which they were placed. The i-th line among the n lines contains two integer numbers l i and ri which are the number of the wall segment occupied by the left end and the right end of the i-th poster, respectively. We know that for each 1 <= i <= n, 1 <= l i <= ri <= 10000000. After the i-th poster is placed, it entirely covers all wall segments numbered l i, l i+1 ,... , ri.
Output
For each input data set print the number of visible posters after all the posters are placed.
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
最开始觉得和zoj1610 count colors应该是一个模板
但是交了以后发现MLE
数据范围太大 没办法直接用数组 所以要离散化
第一次用到离散化 学了个新内容 代码是借鉴了题解
eg 范围[1,6] [1.7] [2,10] [8 18] 将各点排序
1 1 2 6 7 8 10 18 离散后对应的坐标为
1 2 3 4 5 6 7 再根据原来的点把它们对应起来,则离散后坐标为
[1,3] [1,4] [2,6] [5,7]
离散化代码
for(int i = 0; i < n * 2; i += 2){
//int a, b;
scanf("%d%d",&post[i].x,&post[i + 1].x);
post[i].id = post[i + 1].id = i;
}
sort(post, post + 2 * n, cmp1);
int tot = 0, pre = 0;
for(int i = 0; i < 2 * n; i++){
if(post[i].x == pre)
post[i].x = tot;
else{
pre = post[i].x;
post[i].x = ++tot;
}
}
从后往前贴 能保证已经能看见的poster里总能有最后的一部分不会被遮住
如果发现这段区域已经被完全覆盖了就返回
完整代码
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<iostream>
#include<limits>
#include<stack>
#include<queue>
#include<cmath>
#define inf 1000005
//Ïß¶ÎÊ÷DÌâ
//http://blog.csdn.net/dt2131/article/details/52919953
//http://www.cnblogs.com/jackge/archive/2013/04/25/3041637.html
using namespace std;
const int maxn = 100010;
int c, n,flag;
//int tree[maxn << 2], dis[maxn];
bool vis[maxn];
struct node{
int id, x;
}post[maxn << 2];
struct Tree{
int l, r;
bool vis;
}tree[maxn << 2];
void build(int L, int R, int rt)
{
tree[rt].l = L;
tree[rt].r = R;
tree[rt].vis = 0;
if(tree[rt].l == tree[rt].r)
return;
int mid = (L + R) / 2;
build(L, mid, rt * 2);
build(mid + 1, R, rt * 2 + 1);
}
void pushup(int rt)
{
tree[rt].vis = tree[2 * rt].vis && tree[2 * rt + 1].vis;
}
/*void pushdown(int rt)
{
if(tree[rt] != -1){
tree[2 * rt] = tree[2 * rt + 1] = tree[rt];
tree[rt] = -1;
}
}
void update(int a, int b, int data, int l, int r, int rt)
{
if(a <= l && b >= r){
tree[rt] = data;
return;
}
if(tree[rt] == data)
return;
pushdown(rt);
int mid = (l + r) / 2;
if(a <= mid)
update(a, b, data, l, mid, 2 * rt);
if(b > mid)
update(a, b, data, mid + 1, r, 2 * rt + 1);
}*/
/*void query(int l, int r, int rt)
{
if(tree[rt] != -1){
for(int i = l; i <= r; i++){
dis[i] = tree[rt];
}
return;
}
if(l != r && tree[rt] == -1){
int mid = (l + r) / 2;
query(l, mid, 2 * rt);
query(mid + 1, r, 2 * rt + 1);
}
}
*/
void query(int L, int R, int rt)
{
if(tree[rt].vis)
return;
if(tree[rt].l == L && tree[rt].r == R)
{
tree[rt].vis = 1;
flag = 1;
return;
}
int mid = (tree[rt].l + tree[rt].r) / 2;
if(R <= mid)
query(L, R, 2 * rt);
else if(L >= mid + 1)
query(L, R, 2 * rt + 1);
else{
query(L, mid, 2 * rt);
query(mid + 1, R, 2 * rt + 1);
}
pushup(rt);
}
bool cmp1(node a, node b)
{
return a.x < b.x;
}
bool cmp2(node a, node b)
{
if(a.id == b.id)
return a.x < b.x;
return a.id > b.id;
}
int main()
{
scanf("%d",&c);
while(c--){
scanf("%d",&n);
//memset(tree, -1, sizeof(tree));
//memset(dis, -1, sizeof(dis));
//int k = 1;
for(int i = 0; i < n * 2; i += 2){
//int a, b;
scanf("%d%d",&post[i].x,&post[i + 1].x);
post[i].id = post[i + 1].id = i;
}
sort(post, post + 2 * n, cmp1);
int tot = 0, pre = 0;
for(int i = 0; i < 2 * n; i++){
if(post[i].x == pre)
post[i].x = tot;
else{
pre = post[i].x;
post[i].x = ++tot;
}
}
build(1, 2 * n, 1);
sort(post, post + 2 * n, cmp2);
int ans = 0;
for(int i = 0; i < 2 * n; i += 2){
int l = post[i].x;
int r = post[i + 1].x;
flag = 0;
query(l, r, 1);
if(flag)
ans++;
}
/*memset(vis, 0, sizeof(vis));
int res = 0;
for(int i = 0; i < maxn;){
while(i < maxn && dis[i] == -1)
i++;
if(i >= maxn)
break;
int temp = dis[i];
if(!vis[temp]){
vis[temp] = true;
res++;
}
//res[temp]++;
while(i < maxn && dis[i] == temp)
i++;
}
/*int ans = 0;
for(int i = 0; i < maxn; i++){
ans += res[i];
}*/
printf("%d\n",ans);
}
return 0;
}
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 —— 线段树染色 + 离散化
题目链接:https://vjudge.net/problem/POJ-2528 The citizens of Bytetown, AB, could not stand that the cand ...
- [poj2528] Mayor's posters (线段树+离散化)
线段树 + 离散化 Description The citizens of Bytetown, AB, could not stand that the candidates in the mayor ...
- poj2528 Mayor's posters(线段树之成段更新)
Mayor's posters Time Limit: 1000MSMemory Limit: 65536K Total Submissions: 37346Accepted: 10864 Descr ...
- POJ2528:Mayor's posters(线段树区间更新+离散化)
Description The citizens of Bytetown, AB, could not stand that the candidates in the mayoral electio ...
- poj2528 Mayor's posters(线段树区间修改+特殊离散化)
Description The citizens of Bytetown, AB, could not stand that the candidates in the mayoral electio ...
- poj2528 Mayor's posters(线段树区间覆盖)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 50888 Accepted: 14737 ...
- POJ.2528 Mayor's posters (线段树 区间更新 区间查询 离散化)
POJ.2528 Mayor's posters (线段树 区间更新 区间查询 离散化) 题意分析 贴海报,新的海报能覆盖在旧的海报上面,最后贴完了,求问能看见几张海报. 最多有10000张海报,海报 ...
- 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 转载自:http://blog.csdn.net/winddreams/article/details/38443761 [题目链接]Mayor's posters [ ...
随机推荐
- Apache中的Order Allow,Deny用法详解
本文讲述了Apache中的Order Allow,Deny用法.分享给大家供大家参考,具体如下: Allow和Deny可以用于apache的conf文件或者.htaccess文件中(配合Directo ...
- Java -- Java 类集 -- 目录
13.1 认识类集 13.1.1 基本概念 13.1.2 类集框架主要接口 13.2 Collection接口 13.2.1 Collection接口的定义 13.2.2 Collection子接口的 ...
- Ubuntu 12.04下安装QQ 2012 Beta3(转)
Ubuntu 12.04下安装QQ 2012 Beta3 由于wine的发展非常迅速.现在网上的利用老版本的wine来安装QQ2012的教程已经有些过时了.实际上操作起来非常简单: 第一步:Ctr ...
- 【代码审计】QYKCMS_v4.3.2 后台down.php页面代码执行漏洞分析
0x00 环境准备 QYKCMS官网:http://www.qykcms.com/ 网站源码版本:QYKCMS_v4.3.2(企业站主题) 程序源码下载:http://bbs.qingyunke. ...
- PHP 搜索分词实现代码
<?php /** * @author: xiaojiang 2014-01-08 * php 建立分词树 * */ class Tree{ public $w = ''; public $su ...
- 架设FTP Server-Windows Server 2012
架设FTP Server-Windows Server 2012 https://jingyan.baidu.com/article/03b2f78c75b9b65ea237ae84.html 在 ...
- DELPHIER,正转向PYTHON了
用了10多年的DELPHI ,现在准备学PYTHON了, 理由是: 1)现在是云计算时代了,需要学习一门适应该时代的语言,研究了很久,PYTHON是最佳选择,排除了PHP,PERL,RUBY等,至于G ...
- update select 多字段
update Countrys set ( Abbreviation_cn, Abbreviation_en, Two_code,Three_code, Number_code)= (select [ ...
- jQuery队列(一)
jQuery的队列依赖缓存机制事件,它同时是animate的基础. 它不像事件机制.缓存机制.回调机制一样有自己的命名空间,由于比较简单,所以直接挂在到$和jQuery对象上. 它提供的基础方法有: ...
- LeetCode 46 Permutations(全排列问题)
题目链接:https://leetcode.com/problems/permutations/?tab=Description Problem:给出一个数组(数组中的元素均不相同),求出这个数组 ...