题目链接

用两条扫描线从左往右扫描,距离为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】窗口的星星的更多相关文章

  1. luogu P1502 窗口的星星

    题目链接 P1502 窗口的星星 题解 扫描线+线段树 线段树的每一个节点处理的是左边框放在当前x-1位置时的框内星星的亮度大小 按照x坐标进行离散化,得到离散化后每一个坐标x的可影响的范围 维护扫描 ...

  2. 洛谷 P1502 窗口的星星 解题报告

    P1502 窗口的星星 题目背景 小卡买到了一套新房子,他十分的高兴,在房间里转来转去. 题目描述 晚上,小卡从阳台望出去,"哇~~~~好多星星啊",但他还没给其他房间设一个窗户, ...

  3. 【Luogu P1502】 窗口的星星

    →传送窗口 (复制一下题面好了~) 题目背景 小卡买到了一套新房子,他十分的高兴,在房间里转来转去. 题目描述 晚上,小卡从阳台望出去,“哇~~~~好多星星啊”,但他还没给其他房间设一个窗户,天真的小 ...

  4. 【Luogu P1502】窗口的星星

    Luogu P1502 题意很好理解,就是问给出的矩形套住的最大和. 但是做起来却十分麻烦. --来自疯狂爆10分的愤怒 一个比较高效的思路是--把每一个星星作为左下角向右上方拓展形成一个矩形, 拓展 ...

  5. 【洛谷 P1502】 窗口的星星(扫描线)

    题目链接 把每个星星作为左下角,做出长为\(w-0.5\),宽为\(h-0.5\)的矩形. \(-0.5\)是因为边框上的不算. 离散化\(y\)坐标. 记录\(2n\)个\(4\)元组\((x,y1 ...

  6. luogu1502 窗口的星星

    扫描线应该打懒标记的-- #include <algorithm> #include <iostream> #include <cstdio> using name ...

  7. 洛谷p1502窗口的星星 扫描线

    题目链接:https://www.luogu.org/problem/P1502 扫描线的板子题,把每个点看成矩形,存下边(x,y,y+h-1,li)和(x+w-1,y,y+h-1),在按横坐标扫线段 ...

  8. Luogu1502 窗口的星星 (线段树扫描线)

    将每个点拓展为矩形,将\(y\)离散,延\(x\)轴扫描,每次更新最值 用了一百年的pushdown操作疑似有问题,亦或这道题特殊,我乱改了pushdown位置就过了,我能怎么办,WA了一发,y数组没 ...

  9. 【学习笔记】线段树—扫描线补充 (IC_QQQ)

    [学习笔记]线段树-扫描线补充 (IC_QQQ) (感谢 \(IC\)_\(QQQ\) 大佬授以本内容的著作权.此人超然于世外,仅有 \(Luogu\) 账号 尚可膜拜) [学习笔记]线段树详解(全) ...

随机推荐

  1. 静下心来学jquery的用法

    http://blog.csdn.net/xiaojun1288/article/details/6803552

  2. jQuery中cookie的简单操作

    jQuery 可以通过 jquery.cookie.js 插件来操作 Cookie. 用NuGet安装:PM>Install-Package js-cookie -Version 官网:http ...

  3. python爬虫---CrawlSpider实现的全站数据的爬取,分布式,增量式,所有的反爬机制

    CrawlSpider实现的全站数据的爬取 新建一个工程 cd 工程 创建爬虫文件:scrapy genspider -t crawl spiderName www.xxx.com 连接提取器Link ...

  4. 47、安装node-sass后运行报错

    vue安装node-sass编译报错安装node-scss报错安装node-scss报错在搭建vue脚手架 或者是在vue项目中,想使用sass的功能, npm install node-sass - ...

  5. java 之 集合概述

    一.集合概述 不管是哪一种数据结构,其实本质上都是容器来着,就是用来装对象的.因此,我们就要搞清楚两点:(1)如何存储(2)存储特点 1.集合 集合是 Java 中提供的一种容器,可以用来存储多个数据 ...

  6. Hive之累计报表生成

    Hive之累计报表生成 1. 原始数据 u01 2019/1/21 5u02 2019/1/23 6u03 2019/1/22 8u04 2019/1/20 3u01 2019/1/23 6u01 2 ...

  7. position 的absolute会使display变成inline-block

    position:absolute和float会隐式地改变display类型,不论之前什么类型的元素(display:none除外), 只要设置了position:absolute. float中任意 ...

  8. 2019年杭电多校第二场 1008题Harmonious Army(HDU6598+最小割+建图)

    题目链接 传送门 题意 有\(n\)个士兵,要你给他们分配职业.有\(m\)对关系,对于某一对关系\(u,v\),如果同为勇士则总能力增加\(a\),同法师则增加\(c\),一个勇士一个法师增加\(\ ...

  9. “SkyReach”对“待就业六人组”和“葫芦娃”的Beta产品测试报告

    对"待就业六人组"的Beta产品测试报告 安装成功截图 第一次上手体验感觉如何?能否正常运行? 第一次上手体验,界面简洁明了,简约的风格比较迎合个人的口味:能够正常运行: 该产品具 ...

  10. python应用-给出行数,输出相应的杨辉三角

    def main(): num = int(input('Number of rows: ')) yh = [[]] * num for row in range(num): yh[row] = [N ...