主要是参考了这个博客 地址戳这儿

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

对于输入要离散化,之后线段树维护张贴的状态。

留意由于一般的离散化可能导致一些区间被“挤压掉”

比如

1-10 1-4 5-10
1-10 1-4 6-10  被处理成了一样的情况导致错漏。

方法是在相差超过1的相邻点插多一个点,使得离散化的时候不会挤压在一起。还有要注意的地方就是空间开多大,一般是要开4倍点空间,但是由于上述增加点的操作会新增加一些点,直接4*2e4是不行的,直接开8×2e4就ok了。

还有,离散化映射的时候能不用STL最好,宁可开个1kw的数组映射,或者用二分法映射,否则容易TLE。

#include <stdio.h>
#include <algorithm>
#include <string.h>
using namespace std; #define FOR(i,a,b) for(int i=(a);i<=(b);++i)
const int maxN=1e4+;
int N, M, K, T; struct Post{int x, y;}nd[maxN];
int g[maxN * ], sg[maxN * ], vis[maxN];
int ans; #define lson l,m,rt*2
#define rson m+1,r,rt*2+1 void push_down(int rt) {
if (sg[rt] == -) return;
sg[rt * ] = sg[rt * + ] = sg[rt];
sg[rt] = -;
}
void update(int L, int R, int C, int l, int r, int rt) {
if (L <= l && r <= R) {
sg[rt] = C;
return;
}
push_down(rt);
int m = (l + r) / ;
if (L <= m) update(L, R, C, lson);
if (R > m) update(L, R, C, rson);
}
void query(int l, int r, int rt) {
if (sg[rt] != -) {
if (vis[sg[rt]] == )
++ans;
vis[sg[rt]] = ;
return;
}
if (l == r) return;
int m = (l + r) / ;
query(lson);
query(rson);
} int main () {
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
#endif
scanf("%d", &T);
while (T--) {
// 输入及离散化
scanf("%d", &N);
int cnt = ;
FOR(i, , N) {
scanf("%d%d", &nd[i].x, &nd[i].y);
g[cnt++] = nd[i].x;
g[cnt++] = nd[i].y;
}
sort(g, g + cnt);
int m = unique(g, g + cnt) - g;
int ocnt = m;
FOR(i, , ocnt - )
if (g[i + ] - g[i] > )
g[m++] = g[i] + ;
sort(g, g + m); // 建线段树以及输出答案
memset(sg, -, sizeof sg);
memset(vis, , sizeof vis); FOR(i, , N) {
int l = lower_bound(g, g + m, nd[i].x) - g;
int r = lower_bound(g, g + m, nd[i].y) - g;
update(l, r, i, , m, );
}
ans = ;
query(, m, );
printf("%d\n", ans);
}
return ;
}

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

  1. POJ 2528 Mayor‘s poster 线段树+离散化

    给一块最大为10^8单位宽的墙面,贴poster,每个poster都会给出数据 a,b,表示该poster将从第a单位占据到b单位,新贴的poster会覆盖旧的,最多有10^4张poster,求最后贴 ...

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

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

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

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

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

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

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

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

  6. POJ 2528 Mayor's posters

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

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

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

  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 【区间离散化+线段树区间更新&&查询变形】

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

随机推荐

  1. Java 中 String 的常用方法(一)

    上一篇介绍了 String 中的几个常用构造方法,由 String 这个核心对象发散出去关于字符的编码,字符的字节表达,对 GC 的影响,正则表达式,模式匹配,这可能是 Java 里内涵最丰富的对象了 ...

  2. spring data 自定义接口

    1 spring data jpa 虽然说spring data 提供了很多DAO 接口,但是依然可能不能满足我们日常的使用,所以,有时我们需要自定义接口方法.自定义接口方法步骤如下: 1.  创建自 ...

  3. memcached 学习笔记 5

     memcached installed on linux 使用的操作系统是centos6.5 (有桌面) 1 上传libebent和memcache到/usr/local/src [root@jt ...

  4. JVM内存模型和垃圾回收

    Java开发有个很基础的问题,虽然我们平时接触的不多,但是了解它却成为Java开发的必备基础——这就是JVM.在C++中我们需要手动申请内存然后释放内存,否则就会出现对象已经不再使用内存却仍被占用的情 ...

  5. PHP命名规则

    参考: http://nowhisky.diandian.com/post/2012-08-12/40033898638 就一般约定而言,类.函数和变量的名字应该是能够让代码阅读者能够容易地知道这些代 ...

  6. 经典实用的iptables shell脚本

    先解释一下iptables里的参数意思:A: 添加 (跟链)-I: 插入-p: 跟协议-s: 源IP-d: 目标IP-j: 操作行为-t: 加表--to-source:SNAT用,表示改成的SNAT源 ...

  7. OpenFileDialog 打开文件对话框

    InitialDirectory 对话框的初始目录 Filter 要在对话框中显示的文件筛选器,例如,"文本文件(*.txt)|*.txt|所有文件(*.*)||*.*" Filt ...

  8. RabbitMQ---9、消息确认机制(事务+Confirm)

    转载至:https://blog.csdn.net/u013256816/article/details/55515234 参考资料:https://www.cnblogs.com/520playbo ...

  9. Vue学习笔记:Ref的使用

    官网上的说明 1.了解Vue中的$refs在Vue中是怎么访问到DOM元素的 <div id="app"> <h1>{{ message }}</h1 ...

  10. JAVA基础之——JDK分析io、nio

    在哪儿:jdk\jre\lib\rt.jar package java.io;   package java.nio; 1 分类 1.1 IO 持久化序列化对象并压缩步骤 new FileOutput ...