题意:

      x轴上有一些矩形,问你这些矩形覆盖的面积和是多少。

思路:

      首先范围很大,n很小,果断离散化,然后我们就是求出任意区间的最大值作为当前区间的高,最后在算一遍答案就行了,一开始超时了,离散化的时候用map了,后来改成二分就ac了,感觉题目不是很难,明天得开始学习学习扫描线了,还不知道什么是扫描线呢。


#include<stdio.h>
#include<string.h>
#include<algorithm> #define lson l ,mid ,t << 1
#define rson mid + 1 ,r ,t << 1 | 1 using namespace std; typedef struct
{
__int64 a ,b ,c;
}EDGE; EDGE edge[44000]; __int64 Max[330000];
__int64 mark[330000];
__int64 tmp[88000];
__int64 num[88000];
__int64 hash[880000]; __int64 maxx(__int64 x ,__int64 y)
{
return x > y ? x : y;
} void Pushup(__int64 t)
{
Max[t] = maxx(Max[t<<1] ,Max[t<<1|1]);
} void Pushdown(__int64 t)
{
if(mark[t])
{
mark[t<<1] = maxx(mark[t<<1] ,mark[t]);
mark[t<<1|1] = maxx(mark[t<<1|1] ,mark[t]);
Max[t<<1] = maxx(Max[t<<1] ,mark[t]);
Max[t<<1|1] = maxx(Max[t<<1|1] ,mark[t]);
mark[t] = 0;
}
} void BuidTree()
{
memset(Max ,0 ,sizeof(Max));
memset(mark ,0 ,sizeof(mark));
} void Update(__int64 l ,__int64 r ,__int64 t ,__int64 a ,__int64 b ,__int64 c)
{
if(a <= l && b >= r)
{
Max[t] = maxx(Max[t] ,c);
mark[t] = maxx(mark[t] ,c);
return;
}
Pushdown(t);
__int64 mid = (l + r) >> 1;
if(a <= mid) Update(lson ,a ,b ,c);
if(b > mid) Update(rson ,a ,b ,c);
Pushup(t);
} __int64 Query(__int64 l ,__int64 r ,__int64 t ,__int64 a)
{
if(l == r) return Max[t];
Pushdown(t);
__int64 mid = (l + r) >> 1;
if(a <= mid) return Query(lson ,a);
else return Query(rson ,a);
} __int64 search2(__int64 n ,__int64 now)
{
__int64 low ,up ,mid ,ans;
low = 1 ,up = n;
while(low <= up)
{
mid = (low + up) >> 1;
if(now <= num[mid])
{
ans = mid;
up = mid - 1;
}
else low = mid + 1;
}
return ans;
} int main ()
{
__int64 n ,i;
while(~scanf("%I64d" ,&n))
{
__int64 id = 0;
for(i = 1 ;i <= n ;i ++)
{
scanf("%I64d %I64d %I64d" ,&edge[i].a ,&edge[i].b ,&edge[i].c);
tmp[++id] = edge[i].a;
tmp[++id] = edge[i].b;
}
sort(tmp + 1 ,tmp + id + 1);
tmp[0] = -1;
for(id = 0 ,i = 1 ;i <= n * 2 ;i ++)
{
if(tmp[i] == tmp[i-1]) continue;
num[++id] = tmp[i];
} BuidTree(); for(i = 1 ;i <= n ;i ++)
{
__int64 a = search2(id ,edge[i].a);
__int64 b = search2(id ,edge[i].b);
Update(1 ,id ,1 ,a + 1 ,b ,edge[i].c);
} __int64 ans = 0;
for(i = 2 ;i <= id ;i ++)
{
__int64 now = Query(1 ,id ,1 ,i);
now = (num[i] - num[i-1]) * now;
ans += now;
}
printf("%I64d\n" ,ans);
}
return 0;
}

POJ3277 线段树段更新,点询问+二分离散化+暴力的更多相关文章

  1. UVA11992不错的线段树段更新

    题意:       给你一个矩阵,最大20*50000的,然后有三个操作 1 x1 y1 x2 y2 v  把子矩阵的值全部都加上v 2 x1 y1 x2 y2 v  把子矩阵的值全部都变成v 2 x ...

  2. hdu1556 线段树段更新(简单题)

    题意: N个气球排成一排,从左到右依次编号为1,2,3....N.每次给定2个整数a b(a <= b),lele便为骑上他的"小飞鸽"牌电动车从气球a开始到气球b依次给每个 ...

  3. hdu4267线段树段更新,点查找,55棵线段树.

    题意:      给你N个数,q组操作,操作有两种,查询和改变,查询就是查询当前的这个数上有多少,更改是给你a b k c,每次从a到b,每隔k的数更改一次,之间的数不更改,就相当于跳着更新. 思路: ...

  4. poj-----(2528)Mayor's posters(线段树区间更新及区间统计+离散化)

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

  5. POJ2528线段树段更新逆序异或(广告牌)

    题意:      可以这样理解,有一条直线,然后用n条线段去覆盖,最后问全部都覆盖完之后还有多少是没有被完全覆盖的. 思路:      一开始想的有点偏,想到起点排序,然后..失败了,原因是忘记了题目 ...

  6. 线段树区间更新,区间统计+离散化 POJ 2528 Mayor&#39;s posters

    题意:有一个非常长的板子(10000000长),在上面贴n(n<=10000)张海报.问最后从外面能看到几张不同的海报. 由于板子有10000000长,直接建树肯定会爆,所以须要离散化处理,对于 ...

  7. hdu6070(分数规划/二分+线段树区间更新,区间最值)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6070 题意: 给出一个题目提交序列, 从中选出一个正确率最小的子串. 选中的子串中每个题目当且仅当最 ...

  8. HDU 1166 敌兵布阵(线段树单点更新,板子题)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  9. UESTC 1591 An easy problem A【线段树点更新裸题】

    An easy problem A Time Limit: 2000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others ...

随机推荐

  1. POJ-2031(最小生成树+kruskal)

    Building a Space Station POJ-2031 注意,这里的输出需要是%f型而不是%lf型的,否则wa. #include<iostream> #include< ...

  2. 2020年12月-第02阶段-前端基础-CSS Day03

    CSS Day03 盒子模型(CSS重点) css学习三大重点: css 盒子模型 . 浮动 . 定位 主题思路: 理解: 1.能说出盒子模型有那四部分组成 2.能说出内边距的作用以及对盒子的影响 3 ...

  3. elf.h

    1 /* This file defines standard ELF types, structures, and macros. 2 Copyright (C) 1995-2019 Free So ...

  4. concurrentHashMap扩容相关方法详解

    上一个博客中说到了concurrentHashMap的put操作,在put操作之后如果添加了节点,我们首先会把全局的节点数+1,如果满足了扩容条件,我们则进行扩容 我们先从addCount方法说起 / ...

  5. Hystrix 实战经验分享

    一.背景 Hystrix是Netlifx开源的一款容错框架,防雪崩利器,具备服务降级,服务熔断,依赖隔离,监控(Hystrix Dashboard)等功能. 尽管说Hystrix官方已不再维护,且有A ...

  6. iNeuOS工业互联平台,生产过程业务联动控制

    1.概述 工业物联网也好.工业互联网也好或是其他生产系统,反向控制始终无法回避.搞工业最直接.最体现效果的两个方面是采集各种数据和生产过程业务控制,所谓大数据预测和分析,那是仁者见仁.智者见智,下一篇 ...

  7. Java开发工程师面试-基础

    JDK.JRE.JVM有什么区别? JDK:Java Development Kit 针对Java程序员的产品 JRE:Java Runtime Environment是运行Java的环境集合 JVM ...

  8. 全网最详细的Linux命令系列-ls命令

    Linux开始必须要会的命令当属ls,在日常工作中用到ls命令时的频率是很多的,作为一个初学者,可能我只会或者顶多ls -l两种用法.但是ls其实是一个非常实用的指令,ls命令就是list的缩写,ls ...

  9. RabbitMQ 入门 (Go) - 6. 数据持久化(上)

    从本节开始,我介绍一下如何将相关数据持久化到数据库,也就是上图中蓝色的部分. 目前的问题 我先运行 6 个传感器和2 个协调器,这里我使用了批处理文件: 运行后,看一下 RabbitMQ 的管理控制台 ...

  10. Python是啥?为什么这么多职业人和学生就算报班也要学它?!

    嗨,大家好 这里是汐仔 首先我们先来考究一下近几年的头条和新闻. 1.早在2018年python就已经被纳入高考之一了 2.Python加入全国计算机等级考试,从2018年九月起新增为大学计算机二级考 ...