POJ3277 线段树段更新,点询问+二分离散化+暴力
题意:
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 线段树段更新,点询问+二分离散化+暴力的更多相关文章
- UVA11992不错的线段树段更新
题意: 给你一个矩阵,最大20*50000的,然后有三个操作 1 x1 y1 x2 y2 v 把子矩阵的值全部都加上v 2 x1 y1 x2 y2 v 把子矩阵的值全部都变成v 2 x ...
- hdu1556 线段树段更新(简单题)
题意: N个气球排成一排,从左到右依次编号为1,2,3....N.每次给定2个整数a b(a <= b),lele便为骑上他的"小飞鸽"牌电动车从气球a开始到气球b依次给每个 ...
- hdu4267线段树段更新,点查找,55棵线段树.
题意: 给你N个数,q组操作,操作有两种,查询和改变,查询就是查询当前的这个数上有多少,更改是给你a b k c,每次从a到b,每隔k的数更改一次,之间的数不更改,就相当于跳着更新. 思路: ...
- poj-----(2528)Mayor's posters(线段树区间更新及区间统计+离散化)
Mayor's posters Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 43507 Accepted: 12693 ...
- POJ2528线段树段更新逆序异或(广告牌)
题意: 可以这样理解,有一条直线,然后用n条线段去覆盖,最后问全部都覆盖完之后还有多少是没有被完全覆盖的. 思路: 一开始想的有点偏,想到起点排序,然后..失败了,原因是忘记了题目 ...
- 线段树区间更新,区间统计+离散化 POJ 2528 Mayor's posters
题意:有一个非常长的板子(10000000长),在上面贴n(n<=10000)张海报.问最后从外面能看到几张不同的海报. 由于板子有10000000长,直接建树肯定会爆,所以须要离散化处理,对于 ...
- hdu6070(分数规划/二分+线段树区间更新,区间最值)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6070 题意: 给出一个题目提交序列, 从中选出一个正确率最小的子串. 选中的子串中每个题目当且仅当最 ...
- HDU 1166 敌兵布阵(线段树单点更新,板子题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- UESTC 1591 An easy problem A【线段树点更新裸题】
An easy problem A Time Limit: 2000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others ...
随机推荐
- javascript处理HTML的Encode(转码)和解码(Decode)
HTML的Encode(转码)和解码(Decode)在平时的开发中也是经常要处理的,在这里总结了使用javascript处理HTML的Encode(转码)和解码(Decode)的常用方式 一.用浏览器 ...
- vs2019远程调试
VS2019远程调试 这几天遇到个很是纠结的问题,同样的源代码,放在测试服务器,完美运行.但是上线正式环境就是死活显示不出来.于是想到了微软的远程调试功能,这里用VS2019举例. 下载远程访问工具 ...
- celery 与 flask 实现异步任务调度
Flask 定了2中上下文,来实现机遇线程\协程的,wsgi服务的请求(request.session)和存储(g,current_app )过程,通过栈来完成不同线程和协程的上下文切换,在与cele ...
- dubbo实战之四:管理控制台dubbo-admin
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- Python接口测试-保持登录状态
#coding:utf-8import requestsimport json#登录url ="https://passport.cnblogs.com/user/signin"h ...
- Go语言学习笔记——Go语言的make的理解
实例:https://tour.go-zh.org/moretypes/10 谢大<Go Web编程>书中的讲解https://github.com/astaxie/build-web-a ...
- spring 最权威的知识点
1.Spring是什么? Spring是一个轻量级的IoC和AOP容器框架.是为Java应用程序提供基础性服务的一套框架,目的是用于简化企业应用程序的开发,它使得开发者只需要关心业务需求.常见的配置方 ...
- P1540_机器(JAVA语言)
题目背景 小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章. 题目描述 这个翻译软件的原理很简单,它只是从头到尾,依次将每个英文单词用对应的中文含义来替换.对于每个英文单词,软件会先 ...
- ES核心概念和原理
ES:1:倒排索引 基于Document 关键词索引实现 . 根据关键词做索引 相关度 a. 数据结构 i. 包含关键词的Document List ii. 关键词在每个doc中出现的次数 词频 TF ...
- Redis实战篇(二)基于Bitmap实现用户签到功能
很多应用上都有用户签到的功能,尤其是配合积分系统一起使用.现在有以下需求: 签到1天得1积分,连续签到2天得2积分,3天得3积分,3天以上均得3积分等. 如果连续签到中断,则重置计数,每月重置计数. ...