首先通过不断翻转坐标系,假设三个点以横坐标为第一关键字,纵坐标为第二关键字排序后A在B前面,B在C前面。

那么只需要处理以下两种情况:

1.B的纵坐标在AC之间,这时三个点的距离和为$2((x_C+y_C)-(x_A+y_A))$。

可以用线段树处理出每个点作为B时$x_A+y_A$以及$x_C+y_C$的最值,然后更新答案即可。

2.B的纵坐标不超过A的纵坐标,这时三个点的距离和为$2((x_C+y_C)-x_A-y_B)$。

还是考虑枚举B,需要维护它左边每个A与右边每个C合并的答案。

于是用一棵线段树维护A集合,从n到1依次计算。

假设现在处理的是点B,那么先把B从A中删除,然后查询答案,再将B加入C集合中,也就是在A集合里进行区间更新。

时间复杂度$O(n\log n)$。

#include<cstdio>
#include<algorithm>
using namespace std;
const int N=100010,M=262150,inf=1000000000;
int n,i,ansmx,ansmn=inf,c[N],d[N],e[N],fmx[N],fmn[N];
struct P{int x,y;}a[N],b[N];
inline bool cmp(const P&a,const P&b){return a.x==b.x?a.y<b.y:a.x<b.x;}
inline bool cmpb(const P&a,const P&b){return a.x<b.x;}
inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
inline void umax(int&a,int b){if(a<b)a=b;}
inline void umin(int&a,int b){if(a>b)a=b;}
inline int findl(int x){
int l=1,r=n,mid,t;
while(l<=r)if(b[mid=(l+r)>>1].x>=x)r=(t=mid)-1;else l=mid+1;
return t;
}
inline int findr(int x){
int l=1,r=n,mid,t;
while(l<=r)if(b[mid=(l+r)>>1].x<=x)l=(t=mid)+1;else r=mid-1;
return t;
}
namespace Sub1{
struct Node{int mx,mn;}T[M];
void build(int x,int a,int b){
T[x].mx=-inf,T[x].mn=inf;
if(a==b)return;
int mid=(a+b)>>1;
build(x<<1,a,mid),build(x<<1|1,mid+1,b);
}
void ins(int x,int a,int b,int c,int p){
umax(T[x].mx,p),umin(T[x].mn,p);
if(a==b)return;
int mid=(a+b)>>1;
if(c<=mid)ins(x<<1,a,mid,c,p);else ins(x<<1|1,mid+1,b,c,p);
}
int askmx(int x,int a,int b,int c,int d){
if(c<=a&&b<=d)return T[x].mx;
int mid=(a+b)>>1,t=-inf;
if(c<=mid)t=askmx(x<<1,a,mid,c,d);
if(d>mid)umax(t,askmx(x<<1|1,mid+1,b,c,d));
return t;
}
int askmn(int x,int a,int b,int c,int d){
if(c<=a&&b<=d)return T[x].mn;
int mid=(a+b)>>1,t=inf;
if(c<=mid)t=askmn(x<<1,a,mid,c,d);
if(d>mid)umin(t,askmn(x<<1|1,mid+1,b,c,d));
return t;
}
}
namespace Sub2{
struct Node{int mxx,mnx,mxv,mnv,mxt,mnt;}T[M];
inline void tagmx(int x,int p){
umax(T[x].mxv,T[x].mxx+p);
umax(T[x].mxt,p);
}
inline void tagmn(int x,int p){
umin(T[x].mnv,T[x].mnx+p);
umin(T[x].mnt,p);
}
inline void pb(int x){
tagmx(x<<1,T[x].mxt);
tagmx(x<<1|1,T[x].mxt);
tagmn(x<<1,T[x].mnt);
tagmn(x<<1|1,T[x].mnt);
T[x].mxt=-inf,T[x].mnt=inf;
}
inline void up(int x){
T[x].mxx=max(T[x<<1].mxx,T[x<<1|1].mxx);
T[x].mnx=min(T[x<<1].mnx,T[x<<1|1].mnx);
T[x].mxv=max(T[x<<1].mxv,T[x<<1|1].mxv);
T[x].mnv=min(T[x<<1].mnv,T[x<<1|1].mnv);
}
void build(int x,int a,int b){
T[x].mxt=-inf,T[x].mnt=inf;
if(a==b){
T[x].mxx=T[x].mnx=e[a];
T[x].mxv=-inf,T[x].mnv=inf;
return;
}
int mid=(a+b)>>1;
build(x<<1,a,mid),build(x<<1|1,mid+1,b),up(x);
}
void del(int x,int a,int b,int c){
if(a==b){
T[x].mxx=T[x].mxv=-inf;
T[x].mnx=T[x].mnv=inf;
return;
}
pb(x);
int mid=(a+b)>>1;
if(c<=mid)del(x<<1,a,mid,c);else del(x<<1|1,mid+1,b,c);
up(x);
}
void change(int x,int a,int b,int c,int d,int p){
if(c<=a&&b<=d){
tagmx(x,p);
tagmn(x,p);
return;
}
pb(x);
int mid=(a+b)>>1;
if(c<=mid)change(x<<1,a,mid,c,d,p);
if(d>mid)change(x<<1|1,mid+1,b,c,d,p);
up(x);
}
int askmx(int x,int a,int b,int c,int d){
if(c<=a&&b<=d)return T[x].mxv;
pb(x);
int mid=(a+b)>>1,t=-inf;
if(c<=mid)t=askmx(x<<1,a,mid,c,d);
if(d>mid)umax(t,askmx(x<<1|1,mid+1,b,c,d));
return up(x),t;
}
int askmn(int x,int a,int b,int c,int d){
if(c<=a&&b<=d)return T[x].mnv;
pb(x);
int mid=(a+b)>>1,t=inf;
if(c<=mid)t=askmn(x<<1,a,mid,c,d);
if(d>mid)umin(t,askmn(x<<1|1,mid+1,b,c,d));
return up(x),t;
}
}
void solve(){
for(sort(a+1,a+n+1,cmp),i=1;i<=n;i++)b[i].x=a[i].y,b[i].y=i;
for(sort(b+1,b+n+1,cmpb),i=1;i<=n;i++)c[i]=findl(a[i].y),d[b[i].y]=i;
for(i=1;i<=n;i++)e[d[i]]=-a[i].x;
for(Sub1::build(1,1,n),i=1;i<=n;i++){
fmx[i]=Sub1::askmx(1,1,n,1,c[i]);
fmn[i]=Sub1::askmn(1,1,n,1,c[i]);
Sub1::ins(1,1,n,c[i],-a[i].x-a[i].y);
}
for(Sub1::build(1,1,n),i=n;i;i--){
umax(ansmx,Sub1::askmx(1,1,n,c[i],n)+fmx[i]);
umin(ansmn,Sub1::askmn(1,1,n,c[i],n)+fmn[i]);
Sub1::ins(1,1,n,c[i],a[i].x+a[i].y);
}
for(Sub2::build(1,1,n),i=n;i;i--){
Sub2::del(1,1,n,d[i]);
umax(ansmx,Sub2::askmx(1,1,n,c[i],n)-a[i].y);
umin(ansmn,Sub2::askmn(1,1,n,c[i],n)-a[i].y);
Sub2::change(1,1,n,1,findr(a[i].y),a[i].x+a[i].y);
}
}
int main(){
for(read(n),i=1;i<=n;i++)read(a[i].x),read(a[i].y);
solve();
for(i=1;i<=n;i++)a[i].x*=-1,a[i].y*=-1;
solve();
for(i=1;i<=n;i++)a[i].x*=-1;
solve();
for(i=1;i<=n;i++)a[i].x*=-1,a[i].y*=-1;
solve();
return printf("%d\n%d",ansmx*2,ansmn*2),0;
}

  

BZOJ2675 : Bomb的更多相关文章

  1. HDU3555 Bomb[数位DP]

    Bomb Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others)Total Submi ...

  2. Leetcode: Bomb Enemy

    Given a 2D grid, each cell is either a wall 'W', an enemy 'E' or empty '0' (the number zero), return ...

  3. HDU 5934 Bomb(炸弹)

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...

  4. hdu 3622 Bomb Game(二分+2-SAT)

    Bomb Game Time Limit: 10000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  5. Bomb

    Description The counter-terrorists found a time bomb in the dust. But this time the terrorists impro ...

  6. CF 363B One Bomb(枚举)

    题目链接: 传送门 One Bomb time limit per test:1 second     memory limit per test:256 megabytes Description ...

  7. hdu3555 Bomb (记忆化搜索 数位DP)

    http://acm.hdu.edu.cn/showproblem.php?pid=3555 Bomb Time Limit: 2000/1000 MS (Java/Others)    Memory ...

  8. [HDU3555]Bomb

    [HDU3555]Bomb 试题描述 The counter-terrorists found a time bomb in the dust. But this time the terrorist ...

  9. hdu 5934 Bomb

    Bomb Problem Description There are N bombs needing exploding.Each bomb has three attributes: explodi ...

随机推荐

  1. Coursera台大机器学习课程笔记9 -- Logistic Regression

    如果只想得到某种概率,而不是简单的分类,那么该如何做呢?在误差衡量问题上,如何选取误差函数这段很有意思. 接下来是如何最小化Ein,由于Ein是可凸优化的,所以采用的是梯度下降法:只要达到谷底,就找到 ...

  2. 减小Delphi2010程序的尺寸(关闭RTTI反射机制)

    自从Delphi2010增强了RTTI反射机制后,编译出来的程序变得更大了,这是因为默认情况下 Delphi2010 给所有类都加上了RTTI信息(呵呵,不管你用不用它,好像实用价值确实不高,至少目前 ...

  3. DCMTK354之VC++ 2008 MFC应用程序配置完整过程

    花了一个礼拜,终于在VC++2008 MFC 应用程序中完成了首个基于DCMTK354的首个程序ECHOSCUWIN32,现将过程记录下来,便于日后查阅,同时也提供给那些有幸看到此博文而对他们又有帮助 ...

  4. shell 生成指定范围随机数与随机字符串 .

    shell 生成指定范围随机数与随机字符串         分类:             shell              2014-04-22 22:17     20902人阅读     评 ...

  5. macbook air 安装win7双系统

    转自: http://jingyan.baidu.com/article/6d704a13f99f1a28da51ca49.html 1)遇到“No bootable device-insert bo ...

  6. 【Hibernate】Hibernate系列2之Session详解

    Session详解 2.1.概述-一级缓存 2.2.操作session缓存方法 2.3.数据库隔离级别 2.4.持久化状态 2.5.状态转换 2.6.存储过程与触发器

  7. css 中的度量单位

    px 相对长度单位.像素(Pixel). 像素是相对于显示器屏幕分辨率而言的.譬如,WONDOWS的用户所使用的分辨率一般是96像素/英寸.而MAC的用户所使用的分辨率一般是72像素/英寸. em 相 ...

  8. selenium启动Chrome时,加载用户配置文件

    selenium启动Chrome时,加载用户配置文件   Selenium操作浏览器是不加载任何配置的,网上找了半天,关于Firefox加载配置的多点,Chrome资料很少,下面是关于加载Chrome ...

  9. Effecvtive C++笔记:让自己习惯C++

    条款01:视C++为一个语言联绑 C++的四个语言层次: C:C++是以C为基础的.基本数据类型.语句.预处理器.数组.指针等统统来自C. Oject-Oriented C++:面向对象这一特性包含了 ...

  10. javascript动态添加form表单元素

    2014年11月7日 17:10:40 之前写过几篇类似的文章,现在看来比较初级,弄一个高级的简单的 情景: 后台要上传游戏截图,截图数量不确定,因此使用动态添加input节点的方法去实现这个效果 主 ...