Mayor's posters

Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u

Description

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

题目大意:
大体是说有人要竞选需要投票什么的,不用理会,总之后面就是贴海报, 后面的能把前面的海报覆盖,海报每次贴不会到方格中间,
如果一个海报不是完全被贴上就算可以看到,问最后你能看到几张海报(英语渣,反正我是这么理解的) 输入
1 //T个样例
5 //下面5(n)张海报及其范围 1 <= n <= 10000
1 4 //海报的左右边界 1--10000000
2 6
8 10
3 4
7 10 输出
4 能看到4张海报 解题思路:
由于海报粘贴的方式,在外面的绝对不会被里面的遮住,所以倒着来覆盖海报比较方便
主要还是由于海报边界太大需要离散化,如果把海报的每个边界看成一个节点话最多需要的范围就成了20000 节点是80000
不过我不会离散化第一次看了课件,模仿着写的,不过听学长说貌似不算很好的离散化 或者完全不合格的离散化
我用的这种离散化还是要开一个100000000的一维数组 虽然开的下,这道题也能解决,不过学长说如果范围是几亿的话就没办法了
不过这道题还是能过的,新的离散化方法明天再搞吧 下面是代码
/*毕竟我是王宇浩*/
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <cstdlib>
#include <cmath>
#include <cctype>
#define Max(a,b) ((a)>(b)?(a):(b))
#define ls rt<<1
#define rs rt<<1|1
using namespace std;
const int N = ;
int xx[N];//x[i]用来储存海报左右边,排列后节点的位置为i;
int post[N * ];//post[i]用来储存边i应该排列在第几个位置上面
struct Poster
{
int l, r;
}P[N];//P[i]来储存第i张海报的左右边 struct node
{
int l, r;
bool cover;
int Mid()
{
return (l + r) >> ;
} }a[N<<]; int cmp(const void *a, const void *b)
{
int *c, *d;
c = (int *)a;
d = (int *)b;
return *c - *d;
} void Build(int rt, int l, int r)
{
a[rt].l = l, a[rt].r = r, a[rt].cover = false; if(l == r) return ; Build(ls, l, a[rt].Mid());
Build(rs, a[rt].Mid()+, r);
}
void UP(int rt)
{
//如果ls和rs都被覆盖, 则此区域被覆盖
if(a[rt].l == a[rt].r) return;
if(a[ls].cover && a[rs].cover)
a[rt].cover = true;
}
bool Search(int rt, int l, int r)//如果找到此区间未被覆盖,覆盖并返回true, 否则返回false;
{
bool ans;
if(a[rt].cover) return false;
if(a[rt].l == l && a[rt].r == r) {
if(a[rt].cover) return false;
else {
a[rt].cover = true;
return true;
}
}
if(l > a[rt].Mid()) {
ans = Search(rs, l, r);
}
else if(r <= a[rt].Mid()) {
ans = Search(ls, l, r);
}
else {
bool ans1 = Search(ls, l, a[rt].Mid());
bool ans2 = Search(rs, a[rt].Mid() + , r);
ans = ans1 || ans2;
}
UP(rt);//每次放置海报之后就要向上更新
return ans;
} int main()
{
int T, n;
scanf("%d", &T);
while (T--) {
scanf("%d", &n);
int index = ;
for(int i = ; i < n; i++) {
scanf("%d %d", &P[i].l, &P[i].r);
xx[index++] = P[i].l;
xx[index++] = P[i].r;
}
qsort(xx, index, sizeof(xx[]), cmp);//对每个左右边的大小排序,确定其属于的节点位置
int index2 = ;
for(int i = ; i < index; i++) {//每个边的位置确定一下,相同值为一个节点,相邻节点也相邻,不相邻节点之间空一个节点
post[xx[i]] = index2;
if(i == index - ) break;//判断到最后一个,结束循环,因为每次循环保存的都是下个节点的状态,及时结束防止数组越界
if(xx[i + ] - xx[i] == ) index2++;
if(xx[i + ] - xx[i] > ) index2 += ;
}
Build(, , index2);//建立线段树
int ans = ;//保存答案
for(int i = n - ; i >= ; i--) {
if(Search(, post[P[i].l], post[P[i].r])) ans++;//每次贴一张海报,判断会不会被覆盖,不会则答案+1
}
printf("%d\n", ans);
}
}
/*
1
5
1 4
2 6
8 10
3 4
7 10 */

POJ 2528 Mayor's posters的更多相关文章

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

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

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

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

  3. POJ - 2528 Mayor's posters(dfs+分治)

    POJ - 2528 Mayor's posters 思路:分治思想. 代码: #include<iostream> #include<cstdio> #include< ...

  4. POJ.2528 Mayor's posters (线段树 区间更新 区间查询 离散化)

    POJ.2528 Mayor's posters (线段树 区间更新 区间查询 离散化) 题意分析 贴海报,新的海报能覆盖在旧的海报上面,最后贴完了,求问能看见几张海报. 最多有10000张海报,海报 ...

  5. POJ 2528 Mayor's posters 【区间离散化+线段树区间更新&&查询变形】

    任意门:http://poj.org/problem?id=2528 Mayor's posters Time Limit: 1000MS   Memory Limit: 65536K Total S ...

  6. POJ 2528 Mayor's posters(线段树区间染色+离散化或倒序更新)

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

  7. poj 2528 Mayor's posters 线段树区间更新

    Mayor's posters Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://poj.org/problem?id=2528 Descript ...

  8. POJ 2528——Mayor's posters——————【线段树区间替换、找存在的不同区间】

    Mayor's posters Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Sub ...

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

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

随机推荐

  1. 关于Android中ArrayMap/SparseArray比HashMap性能好的深入研究

    由于网上有朋友对于这个问题已经有了很详细的研究,所以我就不班门弄斧了: 转载于:http://android-performance.com/android/2014/02/10/android-sp ...

  2. Nudnik Photographer -Ural1260动态规划

    Time limit: 1.0 second Memory limit: 64 MB If two people were born one after another with one second ...

  3. hive相关

    HIVE JOIN:http://blog.csdn.net/yfkiss/article/details/8073608 HIVE资料: 一条记录map阶段输出KV,shuffle sort,输出K ...

  4. Socket之TCP连接_TcpNoDelay

    摘自: http://jerrypeng.me/2013/08/mythical-40ms-delay-and-tcp-nodelay/

  5. SQL2008 的 日期数据类型

    摘要 你是否曾经想在数据库中存储一个日期而没有时间部分,或者想存储一个时间值希望有更高的精度?在SQL Server 2008的介绍中,微软介绍了一些新的日期数据类允许你只存储一个日期.更高精度的时间 ...

  6. 什么是原生的javascript

    在www.cocos.com的cocos2d-js的介绍中写道“Cocos2d-JS 是跨全平台的游戏引擎,采用原生JavaScript语言,可发布到包括Web平台,iOS,Android,Windo ...

  7. windows平台解决quick3.5final + sublimeText3 模拟器找不到的问题

    下载了quick3.5 准备在sublime上进行开发,结果发现quick3.5中的player模拟器不见了,原来模拟器移到了quick引擎主目录下的 /tools/simulator/runtime ...

  8. 开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别

    以下是上述协议的简单介绍:BSD开源协议BSD开源协议是一个给于使用者很大自由的协议.基本上使用者可以”为所欲为”,可以自由的使用,修改源代码,也可以将修改后的代码作为开源或者专有软件再发布. 但”为 ...

  9. MFC编程入门之二十六(常用控件:滚动条控件ScrollBar)

    回顾上一节,讲的是组合框控件Combo Box的使用.本节详解滚动条控件Scroll Bar的相关内容. 滚动条控件简介 滚动条大家也很熟悉了,Windows窗口中很多都有滚动条.前面讲的列表框和组合 ...

  10. maven-web项目中的一些小问题

    1.最新的jetty容器 org.eclipse.jetty 需要JDK1.8的支持. 2.在容器中发布WEB项目时web 中的pom.xml的依赖关系会丧失,依赖和插件需要单独完全编写(尽管IDE会 ...