【louguP1502】窗口的星星
用两条扫描线从左往右扫描,距离为W,右边的扫描线扫到就加上,左边的扫到就减去,
线段树上的一点\(x\)维护\((x,x+H)\)的星星总价值,修改时直接修改\((x-H,x)\)就行了
坐标大,离散化
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#define lc (p<<1)
#define rc (p<<1|1)
#define int long long
using namespace std;
const int MAXN=20010;
const int MAXM=400010;
inline int read(){
int x=0; char c=getchar();
while(c<'0') c=getchar();
while(c>='0') x=x*10+c-'0',c=getchar();
return x;
}
int T,n,W,H,mx[MAXN],Ans;
struct NODE{
int x,nx,y,l,lx;
}a[MAXN];
inline bool cmp1(NODE p,NODE q){
return p.x<q.x;
}
inline bool cmp2(NODE p,NODE q){
return p.y<q.y;
}
int maxx[MAXM],tag[MAXM];
inline void push_up(int p){
maxx[p]=max(maxx[lc],maxx[rc]);
}
inline void push_down(int p,int l,int r){
if(tag[p]){
int &d=tag[p];
maxx[lc]+=d; maxx[rc]+=d;
tag[lc]+=d; tag[rc]+=d;
d=0;
}
}
inline void update(int L,int R,int d,int p=1,int l=1,int r=n){
if(L<=l&&r<=R){
maxx[p]+=d;
tag[p]+=d;
return;
}
push_down(p,l,r);
int mid=(l+r)>>1;
if(L<=mid) update(L,R,d,lc,l,mid);
if(R>mid) update(L,R,d,rc,mid+1,r);
push_up(p);
}
signed main()
{
T=read();
while(T--){
memset(maxx,0,sizeof(maxx));
memset(tag,0,sizeof(tag));
memset(mx,0,sizeof(mx));
Ans=0;
n=read(); H=read(); W=read();
for(int i=1;i<=n;++i)
a[i].x=read(),a[i].y=read(),a[i].l=read();
sort(a+1,a+1+n,cmp1);
int cnt=0;
for(int i=1;i<=n;++i){
a[i].nx=(a[i].x==a[i-1].x)?cnt:++cnt;
mx[a[i].nx]=a[i].x;
}
int j=1;
for(int i=1;i<=n;++i){
while(a[i].x-mx[j]>=H) ++j;
a[i].lx=j;
}
sort(a+1,a+1+n,cmp2);
int l=1,r=1;
while(r<=n){
update(a[r].lx,a[r].nx,a[r].l);
while(a[r].y-a[l].y>=W)
update(a[l].lx,a[l].nx,-a[l].l),++l;
Ans=max(Ans,maxx[1]);
++r;
}
printf("%lld\n",Ans);
}
return 0;
}
/*
3
3 5 4
1 2 3
2 3 2
6 3 1
3 5 4
1 2 3
2 3 2
5 3 1
4 3 3
1 1 1
2 2 3
3 4 2
4 1 1
*/
【louguP1502】窗口的星星的更多相关文章
- luogu P1502 窗口的星星
题目链接 P1502 窗口的星星 题解 扫描线+线段树 线段树的每一个节点处理的是左边框放在当前x-1位置时的框内星星的亮度大小 按照x坐标进行离散化,得到离散化后每一个坐标x的可影响的范围 维护扫描 ...
- 洛谷 P1502 窗口的星星 解题报告
P1502 窗口的星星 题目背景 小卡买到了一套新房子,他十分的高兴,在房间里转来转去. 题目描述 晚上,小卡从阳台望出去,"哇~~~~好多星星啊",但他还没给其他房间设一个窗户, ...
- 【Luogu P1502】 窗口的星星
→传送窗口 (复制一下题面好了~) 题目背景 小卡买到了一套新房子,他十分的高兴,在房间里转来转去. 题目描述 晚上,小卡从阳台望出去,“哇~~~~好多星星啊”,但他还没给其他房间设一个窗户,天真的小 ...
- 【Luogu P1502】窗口的星星
Luogu P1502 题意很好理解,就是问给出的矩形套住的最大和. 但是做起来却十分麻烦. --来自疯狂爆10分的愤怒 一个比较高效的思路是--把每一个星星作为左下角向右上方拓展形成一个矩形, 拓展 ...
- 【洛谷 P1502】 窗口的星星(扫描线)
题目链接 把每个星星作为左下角,做出长为\(w-0.5\),宽为\(h-0.5\)的矩形. \(-0.5\)是因为边框上的不算. 离散化\(y\)坐标. 记录\(2n\)个\(4\)元组\((x,y1 ...
- luogu1502 窗口的星星
扫描线应该打懒标记的-- #include <algorithm> #include <iostream> #include <cstdio> using name ...
- 洛谷p1502窗口的星星 扫描线
题目链接:https://www.luogu.org/problem/P1502 扫描线的板子题,把每个点看成矩形,存下边(x,y,y+h-1,li)和(x+w-1,y,y+h-1),在按横坐标扫线段 ...
- Luogu1502 窗口的星星 (线段树扫描线)
将每个点拓展为矩形,将\(y\)离散,延\(x\)轴扫描,每次更新最值 用了一百年的pushdown操作疑似有问题,亦或这道题特殊,我乱改了pushdown位置就过了,我能怎么办,WA了一发,y数组没 ...
- 【学习笔记】线段树—扫描线补充 (IC_QQQ)
[学习笔记]线段树-扫描线补充 (IC_QQQ) (感谢 \(IC\)_\(QQQ\) 大佬授以本内容的著作权.此人超然于世外,仅有 \(Luogu\) 账号 尚可膜拜) [学习笔记]线段树详解(全) ...
随机推荐
- spring boot EnableAutoConfiguration exclude 无效
本文链接:https://blog.csdn.net/ID19870510/article/details/79373386 首先讲一下SpringBootApplication注解源码定义为 @Ta ...
- 使用国内作者制作的gcr.io镜像安装工具
项目地址:https://github.com/zhangguanzhang/gcr.io How to use? 拉取 假设需要拉取gcr.io/google_containers/pause:3. ...
- 突破Java面试-Redis集群模式的原理
1 面试题 Redis集群模式的工作原理说一下?在集群模式下,key是如何寻址的?寻址都有哪些算法?了解一致性hash吗? 2 考点分析 Redis不断在发展-Redis cluster集群模式,可以 ...
- English--并列句
English|并列句 现在开始讲解英语中的最简单的长句,即并列句. 前言 目前所有的文章思想格式都是:知识+情感. 知识:对于所有的知识点的描述.力求不含任何的自我感情色彩. 情感:用我自己的方式, ...
- Spring Aware获取Bean和其他对象
Spring的容器托管了所有bean,实际项目中我们经常会用到容器中的功能资源,这时候就用到了 Spring Aware.简单来说,就是Spring Aware可以帮助你获取到Spring容器中的Be ...
- consul:kv
consul除了提供了服务发现的功能,还是提供了kv store的功能,kv store可用于动态配置服务.协调服务.leader选举等场景. consul的kv提供了cli和http的两种接口: h ...
- 12306 抢票项目霸榜 GitHub,标星即将破万
十一将至,你买到回家的火车票了吗?如果没有,你可以试着打开 GitHub,在搜索栏键入 12306 的关键词,我相信你会发现一个新大陆.没错,这里有 1572 个抢票项目.它们大多用 Python.J ...
- Django-ModelFrom中修改save后的字段值
在ModelForm提交中,保持原未修改字段的值,views中部分代码: project = Iredmail.objects.get(id=id) ssh_crt_name = project.ss ...
- C#的静态类
静态类 静态类与非静态类的重要区别在于静态类不能实例化,也就是说,不能使用 new 关键字创建静态类类型的变量.在声明一个类时使用static关键字,具有两个方面的意义:首先,它防止程序员写代码来实例 ...
- mysql float和decimal
结论: 1. float 默认只保存6位(除去小数点),如果超过6位,则四舍五入,所以float存储的数据是不精确的,只是近似值: 2. decimal,如果输入的数据超过了定义的最大值,那么则溢出, ...