#1079 : 离散化

时间限制:10000ms
单点时限:1000ms
内存限制:256MB

描写叙述

小Hi和小Ho在回国之后,又一次过起了朝7晚5的学生生活。当然了。他们还是在一直学习着各种算法~

这天小Hi和小Ho所在的学校举办社团文化节,各大社团都在宣传栏上贴起了海报,可是贴来贴去,有些海报就会被其它社团的海报所遮挡住。看到这个场景,小Hi便产生了这种一个疑问——最后究竟能有几张海报还能被看见呢?

于是小Ho肩负起了解决问题的责任:由于宣传栏和海报的高度都是一样的。所以宣传栏能够被视作长度为L的一段区间。且有N张海报依照顺序依次贴在了宣传栏上。当中第i张海报贴住的范围能够用一段区间[a_i, b_i]表示。当中a_i, b_i均为属于[0, L]的整数。而一张海报能被看到当且仅当存在长度大于0的一部分没有被后来贴的海报所遮挡住。

那么问题就来了:到底有几张海报能被看到呢?

提示一:正确的认识信息量

提示二:小Hi大讲堂之线段树的节点意义

输入

每一个測试点(输入文件)有且仅有一组測试数据。

每组測试数据的第1行为两个整数N和L,分别表示总共贴上的海报数量和宣传栏的宽度。

每组測试数据的第2-N+1行,依照贴上去的先后顺序。每行描写叙述一张海报。当中第i+1行为两个整数a_i, b_i。表示第i张海报所贴的区间为[a_i, b_i]。

对于100%的数据。满足N<=10^5,L<=10^9,0<=a_i<b_i<=L。

输出

对于每组測试数据,输出一个整数Ans。表示总共同拥有多少张海报能被看到。

例子输入
5 10
4 10
0 2
1 6
5 9
3 4
例子输出
5

待理解。。。

AC代码:

#include <map>
#include <set>
#include <cmath>
#include <deque>
#include <queue>
#include <stack>
#include <cstdio>
#include <cctype>
#include <string>
#include <vector>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define INF 0x7fffffff
using namespace std; const int maxn = 200005; struct Poster {
int l, r;
}pt[maxn]; struct Tree {
int l ,r;
int c;
int mid() { return (l + r) >> 1; }
}node[maxn << 2]; int d[maxn];
int c; int used[maxn]; void build(int l, int r, int rt) {
node[rt].l = l;
node[rt].r = r;
node[rt].c = 0;
if(l + 1 == r) {
return;
}
int mid = node[rt].mid();
build(l, mid, rt << 1);
build(mid, r, rt << 1 | 1);
} void update(int l, int r, int c, int rt) {
if(l <= node[rt].l && node[rt].r <= r) {
node[rt].c = c;
return;
}
int mid = node[rt].mid();
if(node[rt].c != -1) { //有新的海报贴进来,所以说要将当前这一块往下更新
node[rt << 1].c = node[rt << 1 | 1].c = node[rt].c;
node[rt].c = -1;
} //对于当前区间的三种情况
if (r <= mid) update(l, r, c, rt << 1);
else if (l >= mid) update(l, r, c, rt << 1 | 1);
else
{
update(l, mid, c, rt << 1);
update(mid, r, c, rt << 1 | 1);
}
} void query(int rt)
{
if (node[rt].c != -1)
{
used[node[rt].c] = 1;
return;
}
query(rt << 1);
query(rt << 1 | 1);
} int main() {
int n, l;
scanf("%d %d", &n, &l); if(n == 0) {
printf("0\n");
return 0;
} c = 0;
for(int i = 1; i <= n; i ++) {
scanf("%d %d", &pt[i].l, &pt[i].r);
d[c ++] = pt[i].l;
d[c ++] = pt[i].r;
used[i] = 0;
} sort(d, d + c); c = unique(d, d + c) - d; //去重 // for(int i = 0; i < c; i ++) {
// cout << d[i] << " ";
// }
// cout << endl; build(0, 2 * c + 1, 1); for(int i = 1; i <= n; i ++) { //模拟离散化贴海报的过程。从1到n张海报
int x = lower_bound(d, d + c, pt[i].l) - d;
int y = lower_bound(d, d + c, pt[i].r) - d;
// cout << x << " " << y << " " << (x << 1) << " " << (y << 1 | 1) << endl;
update(x << 1, y << 1 | 1, i, 1);
} query(1);
int ans = 0;
for (int i = 1; i <= n; i ++) ans += used[i];
printf("%d\n", ans); return 0;
}

hihoCoder - 1079 - 离散化 (线段树 + 离散化)的更多相关文章

  1. hihoCoder:#1079(线段树+离散化)

    题目大意:给n个区间,有的区间可能覆盖掉其他区间,问没有完全被其他区间覆盖的区间有几个?区间依次给出,如果有两个区间完全一样,则视为后面的覆盖前面的. 题目分析:区间可能很长,所以要将其离散化.但离散 ...

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

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

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

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

  4. 南阳理工 题目9:posters(离散化+线段树)

    posters 时间限制:1000 ms  |  内存限制:65535 KB 难度:6   描述 The citizens of Bytetown, AB, could not stand that ...

  5. [poj2528] Mayor's posters (线段树+离散化)

    线段树 + 离散化 Description The citizens of Bytetown, AB, could not stand that the candidates in the mayor ...

  6. SGU 180 Inversions(离散化 + 线段树求逆序对)

    题目链接:http://acm.sgu.ru/problem.php?contest=0&problem=180 解题报告:一个裸的求逆序对的题,离散化+线段树,也可以用离散化+树状数组.因为 ...

  7. [UESTC1059]秋实大哥与小朋友(线段树, 离散化)

    题目链接:http://acm.uestc.edu.cn/#/problem/show/1059 普通线段树+离散化,关键是……离散化后建树和查询都要按照基本法!!!RE了不知道多少次………………我真 ...

  8. 【POJ】2528 Mayor's posters ——离散化+线段树

    Mayor's posters Time Limit: 1000MS    Memory Limit: 65536K   Description The citizens of Bytetown, A ...

  9. hpu校赛--雪人的高度(离散化线段树)

    1721: 感恩节KK专场——雪人的高度 时间限制: 1 Sec  内存限制: 128 MB 提交: 81  解决: 35 [提交][状态][讨论版] 题目描述 大雪过后,KK决定在春秋大道的某些区间 ...

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

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

随机推荐

  1. Python安装distribute包

    从官网https://pypi.python.org/pypi/distribute/0.6.49#downloads上下载distribute包,解压后进入解压文件的目录下,使用 python se ...

  2. Skeleton Screen — 骨架屏

    用户体验一直是前端开发需要考虑的重要部分,在数据请求时常见到锁屏的loading动画,而现在越来越多的产品倾向于使用Skeleton Screen Loading(骨架屏)替代,以优化用户体验. Sk ...

  3. SQL练习题_用户购买收藏记录合并(拼多多)

    目录 拼多多笔试题0805_统计用户数据 笔试题描述 表格构建 数据观察 题目分析 一.合并表格 二.CASE表示(0,1) 三.同理复制FORK表 题目解答 拼多多笔试题0805_统计用户数据 笔试 ...

  4. html5——应用缓存

    基本概念 1.HTML5中我们可以轻松的构建一个离线(无网络状态)应用,只需要创建一个cache manifest文件 2.可配置需要缓存的资源,网络无连接应用仍可用,本地读取缓存资源,提升访问速度, ...

  5. dotnetnuke 7.x登录时不跳到站点设置中的指定页

    查源码发现登录按钮有参数,点击跳到登录页或者弹窗登录,真正登录后会根据传参的url反回.因为皮肤对像没有相应参数,所以只能去掉参数.我是用js去的,偷个懒吧.如下所示: <script type ...

  6. Spring学习_day03_事务

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! Spring_day03 一.事务 1.1 事务 事务 ...

  7. 移动的 touch事件中的touches、targetTouches和changedTouches

    touches: 当前屏幕上所有触摸点的列表; targetTouches: 当前对象上所有触摸点的列表; changedTouches: 涉及当前(引发)事件的触摸点的列表 通过一个例子来区分一下触 ...

  8. php省市区三级联动

    效果 步骤 前端:通过ajax请求获取数据,使用了jquery 页面一开始加载所有省份信息 ->当选择省下拉框后触发改变监听时间-change ->当选择市下拉框后触发改变监听时间-cha ...

  9. final关键字用法

    Java关键字final有“这是无法改变的”或者“终态的”含义,它可以修饰非抽象类.非抽象类成员方法和变量. final类不能被继承,没有子类,final类中的方法默认是final的. final方法 ...

  10. thinkphp里模版文件js无法使用if condition的问题

    /**     * @example   thinkphp里模版文件js无法使用if condition的问题     * @example  参考地址:https://segmentfault.co ...