luogu P1502 窗口的星星
题目链接
题解
扫描线+线段树
线段树的每一个节点处理的是左边框放在当前x-1位置时的框内星星的亮度大小
按照x坐标进行离散化,得到离散化后每一个坐标x的可影响的范围
维护扫描线,扫到可以加某颗星星就把星星加进去,扫到该出来的时候就把星星搞出来,线段树维护一下
代码
#include<cstdio>
#include<cstring>
#include<algorithm>
const int maxn = 100007;
int n,w,h;
int pou[maxn << 2],T[maxn << 2],tag[maxn << 2];
struct P {
int x,y,l,k,ymax,id;
}star[maxn << 2];
inline bool cmp1(P a,P b) { return a.y < b.y; }
inline bool cmp2(P a,P b) { if(a.id == b.id) return a.k < b.k; return a.id < b.id; }
inline bool cmp3(P a,P b) { if(a.x == b.x) return a.k < b.k; return a.x < b.x; }
void pushdown(int x,int l,int r) {
if(!tag[x]) return;
if(l == r) { tag[x] = 0; return; }
int mid = l + r >> 1;
tag[x << 1] += tag[x]; tag[x << 1 | 1] += tag[x];
T[x << 1] += tag[x]; T[x << 1 | 1]+=tag[x];
tag[x] = 0;
}
void modify(int x,int l,int r,int tl,int tr,int val){
pushdown(x,l,r);
if(tl <= l && r <= tr) {
tag[x] = val; T[x] += val;
return;
}
int mid = (l + r) >> 1;
if(tl <= mid) modify(x << 1,l,mid,tl,tr,val);
if(mid < tr) modify(x << 1 | 1,mid + 1,r,tl,tr,val);
T[x] = std::max(T[x << 1],T[x << 1 | 1]);
}
void init() {
memset(T,0,sizeof(T));
memset(tag,0,sizeof(tag));
scanf("%d%d%d",&n,&w,&h);
for(int x,y,l,i = 1;i <= n ;++ i) {
scanf("%d%d%d",&x,&y,&l);
star[i] = (P) {x, y, l, 1};
star[i + n] = (P){ x + w - 1, y, -l, 2};
star[i + (n << 1)].y = y + h - 1;
star[i + (n << 1)].k = 3;
star[i].id = star[i + n].id = star[i + (n << 1)].id = i;
}
}
void solve() {
std::sort(star + 1,star + n * 3 + 1,cmp1);
int cnt = 0;
for(int i = 1;i <= n * 3;++ i) pou[i] = star[i].y;
for(int i = 1;i <= n * 3;++ i)
if(star[i].y == pou[i - 1]) star[i].y = star[i - 1].y;
else star[i].y =++ cnt;
std::sort(star + 1,star + n * 3 + 1,cmp2);
for(int i = 1;i <= n * 3;i += 3) star[i].ymax = star[i + 1].ymax = star[i + 2].y;
for(int i = 3;i <= n << 1;++ i) star[i] = star[i + ((i - 1) >> 1)];
std::sort(star + 1,star + (n << 1) + 1,cmp3);
int ans = 0;
for(int i = 1;i <= n << 1;++ i) {
modify(1,0,cnt,star[i].y,star[i].ymax,star[i].l);
ans = std::max(ans,T[1]);
}
printf("%d\n",ans);
return ;
}
int main() {
int t; scanf("%d",&t);
while(t --) {
init();
solve();
}
return 0;
}
luogu P1502 窗口的星星的更多相关文章
- 洛谷 P1502 窗口的星星 解题报告
P1502 窗口的星星 题目背景 小卡买到了一套新房子,他十分的高兴,在房间里转来转去. 题目描述 晚上,小卡从阳台望出去,"哇~~~~好多星星啊",但他还没给其他房间设一个窗户, ...
- 洛谷p1502窗口的星星 扫描线
题目链接:https://www.luogu.org/problem/P1502 扫描线的板子题,把每个点看成矩形,存下边(x,y,y+h-1,li)和(x+w-1,y,y+h-1),在按横坐标扫线段 ...
- 【Luogu P1502】窗口的星星
Luogu P1502 题意很好理解,就是问给出的矩形套住的最大和. 但是做起来却十分麻烦. --来自疯狂爆10分的愤怒 一个比较高效的思路是--把每一个星星作为左下角向右上方拓展形成一个矩形, 拓展 ...
- 【Luogu P1502】 窗口的星星
→传送窗口 (复制一下题面好了~) 题目背景 小卡买到了一套新房子,他十分的高兴,在房间里转来转去. 题目描述 晚上,小卡从阳台望出去,“哇~~~~好多星星啊”,但他还没给其他房间设一个窗户,天真的小 ...
- 【洛谷 P1502】 窗口的星星(扫描线)
题目链接 把每个星星作为左下角,做出长为\(w-0.5\),宽为\(h-0.5\)的矩形. \(-0.5\)是因为边框上的不算. 离散化\(y\)坐标. 记录\(2n\)个\(4\)元组\((x,y1 ...
- 【louguP1502】窗口的星星
题目链接 用两条扫描线从左往右扫描,距离为W,右边的扫描线扫到就加上,左边的扫到就减去, 线段树上的一点\(x\)维护\((x,x+H)\)的星星总价值,修改时直接修改\((x-H,x)\)就行了 坐 ...
- luogu1502 窗口的星星
扫描线应该打懒标记的-- #include <algorithm> #include <iostream> #include <cstdio> using name ...
- Luogu1502 窗口的星星 (线段树扫描线)
将每个点拓展为矩形,将\(y\)离散,延\(x\)轴扫描,每次更新最值 用了一百年的pushdown操作疑似有问题,亦或这道题特殊,我乱改了pushdown位置就过了,我能怎么办,WA了一发,y数组没 ...
- 【学习笔记】线段树—扫描线补充 (IC_QQQ)
[学习笔记]线段树-扫描线补充 (IC_QQQ) (感谢 \(IC\)_\(QQQ\) 大佬授以本内容的著作权.此人超然于世外,仅有 \(Luogu\) 账号 尚可膜拜) [学习笔记]线段树详解(全) ...
随机推荐
- Java基础-SSM之Spring和Mybatis以及Spring MVC整合案例
Java基础-SSM之Spring和Mybatis以及Spring MVC整合案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 能看到这篇文章的小伙伴,详细你已经有一定的Java ...
- Java基础-SSM之mybatis的树形控件(自关联)
Java基础-SSM之mybatis的树形控件(自关联) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.准备测试环境(创建数据库表) 1>.创建areas表: use y ...
- WinFrom弹出输入框
代码上面要引用 using Microsoft.VisualBasic; 还不够,在解决方案的引用那里,也要添加引用 如此,便可打出输入框了: ,); 5个参数分别的意思: 提示信息 标题 如果用户没 ...
- PDF截取矢量图
PDF截取矢量图 觉得有用的话,欢迎一起讨论相互学习~Follow Me 方法与步骤 下载并安装 Adobe Acrobat X Pro 软件 点击右侧按钮(工具)-页面-裁剪-单击并选择区域-双击实 ...
- python---django使用cookie和session
在views中的调用: def login(req): message='' if req.method == "POST": user = req.POST.get(" ...
- Spark记录-Scala字符串
Scala字符串 在Scala中的字符串和Java中的一样,字符串是一个不可变的对象,也就是一个不能修改的对象.可以修改的对象,如数组,称为可变对象.字符串是非常有用的对象,在本节的最后部分,我们将介 ...
- git高清技能图
----
- 洛谷 P3994 高速公路
https://www.luogu.org/problemnew/show/P3994 设dp[i] 表示第i个城市到根节点的最小花费 dp[i]=min{ (dis[i]-dis[j])*P[i]+ ...
- elementUI下拉框错误记录
选择广东省深圳市,保存,再编辑是这样效果 原因 保存的那张表相关字段为字符串,而生成下拉框该字段是整数,两者改成一致即可 修改后
- koa1.x获取原始body内容
Node版本比较老,koa1.x配合koa-body-parser,默认koa-body-parser会把请求数据转成json对象, 然而有的时候需要获取原始的内容,不要转换,看波koa-body-p ...