题目链接:http://poj.org/problem?id=2528

题目大意:有一个很上的面板, 往上面贴海报, 问最后最多有多少个海报没有被完全覆盖

解题思路:将贴海报倒着想, 对于每一张海报只需要判断他要贴的位置是否已经全部被之前的海报覆盖就可以了, 如果没有被覆盖那么这个海报最后是没有被完全覆盖的, 如果被覆盖了, 那么最后是被完全覆盖的。标准的线段树题目.

代码如下:

#include<stdio.h>
#include<vector>
#include<map>
#include<algorithm>
using namespace std;
const int N = ; pair<int, int>edge[N];
vector<int> vec;
map<int, int> mp; struct SegmentTree
{
int l, r;
bool mk;
bool lazy;
}; SegmentTree tree[N << ]; void build(int l, int r, int k)
{
tree[k].l = l, tree[k].r = r, tree[k].mk = false, tree[k].lazy = false;
if(l== r)
return;
int mid = (l + r) >> ;
build(l, mid, k<<);
build(mid+, r, k<<|);
} bool query(int l, int r, int k)
{
if(tree[k].mk)
return true; if(tree[k].l >= l && tree[k].r <= r)
return tree[k].mk; bool a = true, b = true;
if(tree[k<<].r >= l)
a = query(l, r, k<<);
if(tree[k<<|].l <= r)
b = query(l, r, k<<|);
return (a && b);
} void updata(int l, int r, int k)
{
if(tree[k].l >= l && tree[k].r <= r)
{
tree[k].mk = true;
tree[k].lazy = true;
return;
} if(tree[k].lazy)
{
tree[k<<].lazy = tree[k<<|].lazy = true;
tree[k].lazy = false;
tree[k<<].mk = tree[k<<|].mk = true;
}
if(tree[k<<].r >= l)
updata(l, r, k<<);
if(tree[k<<|].l <= r)
updata(l, r, k<<|); tree[k].mk = (tree[k<<].mk && tree[k<<|].mk);
} void solve()
{
int n;
scanf("%d", &n);
vec.clear();
for(int i=; i<n; ++ i)
{
scanf("%d%d", &edge[i].first, &edge[i].second);
vec.push_back(edge[i].first);
vec.push_back(edge[i].second);
} sort(vec.begin(), vec.end());
vec.erase(unique(vec.begin(), vec.end()), vec.end()); mp.clear();
int s = ;
for(int i=; i<vec.size(); ++ i)
{
mp[vec[i]] = s;
if(i != vec.size() - )
{
if(vec[i+] == vec[i] + )
s ++;
else
s += ;
}
} build(, s, ); int ans = ;
for(int i=n-; i>=; -- i)
{
int l = mp[edge[i].first], r = mp[edge[i].second];
if(query(l, r, ) == false)
{
ans ++;
updata(l, r, );
}
}
printf("%d\n", ans);
} int main()
{
int t;
scanf("%d", &t);
while(t --)
solve();
return ;
}

POJ 2528 Mayor's posters (线段树)的更多相关文章

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

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

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

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

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

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

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

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

  5. poj 2528 Mayor's posters 线段树+离散化 || hihocode #1079 离散化

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

  6. poj 2528 Mayor's posters(线段树)

    题目:http://poj.org/problem?id=2528 题意:有一面墙,被等分为1QW份,一份的宽度为一个单位宽度.现在往墙上贴N张海报,每张海报的宽度是任意的, 但是必定是单位宽度的整数 ...

  7. POJ 2528 Mayor's posters (线段树区间更新+离散化)

    题目链接:http://poj.org/problem?id=2528 给你n块木板,每块木板有起始和终点,按顺序放置,问最终能看到几块木板. 很明显的线段树区间更新问题,每次放置木板就更新区间里的值 ...

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

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

  9. POJ 2528 Mayor’s posters (线段树段替换 && 离散化)

    题意 : 在墙上贴海报, n(n<=10000)个人依次贴海报,给出每张海报所贴的范围li,ri(1<=li<=ri<=10000000).求出最后还能看见多少张海报. 分析 ...

随机推荐

  1. linux 查看系统信息

    一.查看内存信息 可以使用free命令显示系统的物理内存和交换分区的总量,以及已使用的.空闲的.共享的.在内核缓冲内的和被缓存的内存数量. 使用free命令可以显示计算机系统的内存容量. [root@ ...

  2. Linux学习三:Ubuntu下使用minicom和开发板通信

    备注:如果你是用的是Windows则使用超级终端即可:开始-程序-附件-通讯-超级终端 现在我们在Ubuntu下安装配置minicom: 1.进入ubuntu桌面ctrl+alt+t打开终端 输入:s ...

  3. .NET牛人应该知道些什么

    任何一个使用.NET的人 1.描述线程与进程的区别? 线程(Thread)与进程(Process)二者都定义了某种边界,不同的是进程定义的是应用程序与应用程序之间的边界,不同的进程之间不能共享代 码和 ...

  4. JS 学习(四)对象

    对象 在JS中,对象是数据(变量),拥有属性和方法. JS中所有事物都是对象:字符串.数字.数组.日期等. 对象是拥有属性和方法的特殊数据类型. 属性是与对象相关的值. 方法是能够在对象上执行的动作. ...

  5. 关于ckeditor 第二次加载 出现问题

    在使用ckeditor 出现的问题也比较多的 ,一个问题是图片上传的问题 ,一个就是第二次加载的时候 ckeditor编辑框出现不了的问题 第一个问题 是修改ckeditor js属性 网上都有  第 ...

  6. linux错误码

    1.通过代码输出错误码以及其代表的含义  具体可以参考errno和os模块 errno.errorcode os.strerror(n) # -*- coding:utf8 -*- import os ...

  7. hrbrid需要做的

    1 返回并刷新 A webveiw push 到 B webview.当由B返回到A时候, A需要刷新页面.

  8. linux下RDP客户端及服务器

    tsclient redsktop remmina   -->对ubuntu支持的非常不错 XRdp 集合vnc作为rdp服务器端使用;

  9. EM算法(1):K-means 算法

    目录 EM算法(1):K-means 算法 EM算法(2):GMM训练算法 EM算法(3):EM算法运用 EM算法(4):EM算法证明 EM算法(1) : K-means算法 1. 简介 K-mean ...

  10. setTimeout 和 setInterval

    设置定时器,在一段时间之后执行指定的代码,setTimeout与setInterval的区别在于setTimeout函数指定的代码仅执行一次 方法一: window.setTimeout(" ...