题意:平面上n个点,每个点带有一个或正或负的权值,让你在平面上放一个内边长为2l,外边长为2r的正方形框,问你最大能圈出来的权值和是多少?

容易推出,能框到每个点的 框中心 的范围也是一个以该点为中心的相同大小的框。

于是,把每个点的框拆成4条线。从下往上扫过去,最下面的线,给[R,R]区间加上该点的权值,然后上面再给[L,L]减去,然后上面再给[L,L]加上,然后再往上在给[R,R]减去即可。每次扫完一行,就用线段树的全局最大值尝试更新答案。

两个坑点:首先,由于线段树里存储的是离散后的点,所以有可能会存在一些死角,所以给离散化后的每两个点之间再插入一个点,这样不会有死角。

其次,出边对应的线要向上移动一个单位,并且左右端点向内缩小一个单位,这样方便处理。

(UPDATE:虽然AC了此题,但是被HACK了,怀疑是“出边对应的线要向上移动一个单位,并且左右端点向内缩小一个单位”这里有BUG)

#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long ll;
struct data{
int p;
ll v;
}t[1200005];
int a[1200005];
bool cmp(const data &a,const data &b){
return a.v<b.v;
}
struct LINE{
int y;
int l,r;
int w;
bool in;
}lines[400005];
bool cm2(const LINE &a,const LINE &b){
return a.y!=b.y ? a.y<b.y : a.in>b.in;
}
int n,L,R,e,zy;
int y[100005],z[100005],ans;
int maxv[4800005],delta[4800005];
void pushdown(int rt){
if(delta[rt]){
delta[rt<<1]+=delta[rt];
delta[rt<<1|1]+=delta[rt];
maxv[rt<<1]+=delta[rt];
maxv[rt<<1|1]+=delta[rt];
delta[rt]=0;
}
}
void update(int ql,int qr,int v,int rt,int l,int r){
if(ql<=l && r<=qr){
maxv[rt]+=v;
delta[rt]+=v;
return;
}
int m=(l+r>>1);
pushdown(rt);
if(ql<=m){
update(ql,qr,v,rt<<1,l,m);
}
if(m<qr){
update(ql,qr,v,rt<<1|1,m+1,r);
}
maxv[rt]=max(maxv[rt<<1],maxv[rt<<1|1]);
}
int main(){
// freopen("a.in","r",stdin);
int x;
scanf("%d%d%d",&n,&L,&R);
for(int i=1;i<=n;++i){
scanf("%d%d%d",&x,&y[i],&z[i]);
t[++e].v=(ll)(x-R)*2ll;
t[e].p=e;
t[++e].v=(ll)(x-R)*2ll-1ll;
t[e].p=e;
t[++e].v=(ll)(x-R)*2ll+1ll;
t[e].p=e; t[++e].v=(ll)(x-L+1)*2ll;
t[e].p=e;
t[++e].v=(ll)(x-L+1)*2ll-1ll;
t[e].p=e;
t[++e].v=(ll)(x-L+1)*2ll+1ll;
t[e].p=e; t[++e].v=(ll)(x+L-1)*2ll;
t[e].p=e;
t[++e].v=(ll)(x+L-1)*2ll-1ll;
t[e].p=e;
t[++e].v=(ll)(x+L-1)*2ll+1ll;
t[e].p=e; t[++e].v=(ll)(x+R)*2;
t[e].p=e;
t[++e].v=(ll)(x+R)*2-1;
t[e].p=e;
t[++e].v=(ll)(x+R)*2+1;
t[e].p=e;
}
sort(t+1,t+e+1,cmp);
a[t[1].p]=++zy;
for(int i=2;i<=e;++i){
if(t[i].v!=t[i-1].v){
++zy;
}
a[t[i].p]=zy;
}
for(int i=1;i<=n;++i){
lines[i*4-3].y=y[i]-R;
lines[i*4-2].y=y[i]-L+1;
lines[i*4-1].y=y[i]+L;
lines[i*4-0].y=y[i]+R+1; lines[i*4-3].l=a[i*12-11];
lines[i*4-2].l=a[i*12-8];
lines[i*4-1].l=a[i*12-8];
lines[i*4-0].l=a[i*12-11]; lines[i*4-3].r=a[i*12-2];
lines[i*4-2].r=a[i*12-5];
lines[i*4-1].r=a[i*12-5];
lines[i*4-0].r=a[i*12-2]; lines[i*4-3].w=z[i];
lines[i*4-2].w=z[i];
lines[i*4-1].w=z[i];
lines[i*4-0].w=z[i]; lines[i*4-3].in=1;
lines[i*4-2].in=0;
lines[i*4-1].in=1;
lines[i*4-0].in=0;
}
sort(lines+1,lines+(n<<2|1),cm2);
for(int i=1;i<=(n<<2);++i){
if(lines[i].in){
update(lines[i].l,lines[i].r,lines[i].w,1,1,zy);
}
else{
update(lines[i].l,lines[i].r,-lines[i].w,1,1,zy);
}
if(lines[i].y!=lines[i+1].y){
ans=max(ans,maxv[1]);
}
}
printf("%d\n",ans);
return 0;
}

【线段树】【扫描线】Petrozavodsk Winter Training Camp 2018 Day 5: Grand Prix of Korea, Sunday, February 4, 2018 Problem A. Donut的更多相关文章

  1. 【推导】【数学期望】【冒泡排序】Petrozavodsk Winter Training Camp 2018 Day 5: Grand Prix of Korea, Sunday, February 4, 2018 Problem C. Earthquake

    题意:两地之间有n条不相交路径,第i条路径由a[i]座桥组成,每座桥有一个损坏概率,让你确定一个对所有桥的检测顺序,使得检测所需的总期望次数最小. 首先,显然检测的时候,是一条路径一条路径地检测,跳跃 ...

  2. 【博弈论】【SG函数】【线段树】Petrozavodsk Summer Training Camp 2016 Day 9: AtCoder Japanese Problems Selection, Thursday, September 1, 2016 Problem H. Cups and Beans

    一开始有n个杯子,每个杯子里有一些豆子,两个人轮流操作,每次只能将一个豆子移动到其所在杯子之前的某个杯子里,不过可以移动到的范围只有一段区间.问你是否先手必胜. 一个杯子里的豆子全都等价的,因为sg函 ...

  3. 【线段树】Petrozavodsk Summer Training Camp 2016 Day 6: Warsaw U Contest, XVI Open Cup Onsite, Sunday, August 28, 2016 Problem H. Hay

    有一些草,一开始高度都是0,它们的生长速率不同. 给你一些单增的日期,在这些日期要将>b的草的部分都割掉,问你每次割掉的部分有多少. 将草的生长速率从大到小排序,这样每次割掉的是一个后缀,而且不 ...

  4. Petrozavodsk Winter Training Camp 2018

    Petrozavodsk Winter Training Camp 2018 Problem A. Mines 题目描述:有\(n\)个炸弹放在\(x\)轴上,第\(i\)个位置为\(p_i\),爆炸 ...

  5. 2015-2016 Petrozavodsk Winter Training Camp, Nizhny Novgorod SU Contest (5/9)

    2015-2016 Petrozavodsk Winter Training Camp, Nizhny Novgorod SU Contest B. Forcefield 题意 给你一维平面上n个镜子 ...

  6. 2015 UESTC Winter Training #7【2010-2011 Petrozavodsk Winter Training Camp, Saratov State U Contest】

    2015 UESTC Winter Training #7 2010-2011 Petrozavodsk Winter Training Camp, Saratov State U Contest 据 ...

  7. 2014-2015 Petrozavodsk Winter Training Camp, Contest.58 (Makoto rng_58 Soejima contest)

    2014-2015 Petrozavodsk Winter Training Camp, Contest.58 (Makoto rng_58 Soejima contest) Problem A. M ...

  8. 【取对数】【哈希】Petrozavodsk Winter Training Camp 2018 Day 1: Jagiellonian U Contest, Tuesday, January 30, 2018 Problem J. Bobby Tables

    题意:给你一个大整数X的素因子分解形式,每个因子不超过m.问你能否找到两个数n,k,k<=n<=m,使得C(n,k)=X. 不妨取对数,把乘法转换成加法.枚举n,然后去找最大的k(< ...

  9. 【BFS】【最小生成树】Petrozavodsk Winter Training Camp 2018 Day 1: Jagiellonian U Contest, Tuesday, January 30, 2018 Problem G. We Need More Managers!

    题意:给你n个点,点带权,任意两点之间的边权是它们的点权的异或值中“1”的个数,问你该图的最小生成树. 看似是个完全图,实际上有很多边是废的.类似……卡诺图的思想?从读入的点出发BFS,每次只到改变它 ...

随机推荐

  1. JS设计模式——11.适配器模式

    适配器模式概述 适配器模式可用来在现有接口和不兼容的类之间进行适配.使用这种模式的对象又叫包装器(wrapper). 适配器特点 从表面看,适配器模式很像门面模式.她们都要对别的对象进行包装并改变其呈 ...

  2. apache服务器yii2报The fileinfo PHP extension is not installed解决思路

    这个问题整整困扰了我两天,今天终于搞定了.记录一下. 背景是这样的,我呢,在centos服务器上安装了lamp环境,其中php是5.3.3,在用composer安装yii2的时候,出现了某些yii2插 ...

  3. 【NOI题解】【bzoj题解】NOI2008 bzoj1063 道路设计

    @ACMLCZH学长出的毒瘤题T3.再也不是“善良”的出题人了. 题意:bzoj. 题解: 经典的树形DP题目,屡见不鲜了,然而我还是没有写出来. 这一类的题目有很多,例如这里的C题. 主要套路是把对 ...

  4. Java高性能并发编程——线程池

    在通常情况下,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的 ...

  5. FPGA设计方法检查表

    -----------------------摘自<FPGA软件测试与评价技术> 中国电子信息产业发展研究院 | 编著------------------------------- 文本格 ...

  6. Linux内核Ramdisk(initrd)机制【转】

    转自:http://www.cnblogs.com/armlinux/archive/2011/03/30/2396827.html 摘要:对于Linux用户来说,Ramdisk并不陌生,可是为什么需 ...

  7. vs2012 连接oracle11g 及数据的insert及select 的总结

    下载链接Oracle 11g所需的驱动ODTwithODAC1120320_32bit,下载链接为http://www.oracle.com/technetwork/topics/dotnet/uti ...

  8. centos7.2系统没有eth0网卡

    最近一直在学centos7.5系统,偶然看到虚拟机里有7.2系统所以想练习一下(其实7.2和7.5差不多),但是打开虚拟机之后,发现没有eth0网卡 那没有eth0网卡就无法远程连接ssh,既然遇到了 ...

  9. HttpClient使用

    1.HttpClient 是 Apache Jakarta Common 下的子项目,可以用来提供高效的.最新的.功能丰富的支持 HTTP 协议的客户端编程工具包 2.主要的功能 (1)实现了所有 H ...

  10. js函数前加分号和感叹号的作用

    js函数前加分号和感叹号是什么意思?有什么用? 一般看JQuery插件里的写法是这样的 (function($) { //... })(jQuery); 今天看到bootstrap的javascrip ...