Problem

BZOJ

Solution

算法:二分+扫描线

快要2019年了,就瞎写一篇博客来凑数,不然感觉太荒凉了……

答案是可二分的,那么二分的依据是什么呢?不妨设当前二分的答案为\(mid\),那么考虑自己和木乃伊在\(mid\)的时间内能够到达的所有格子,组成了一个正方形,如果自己的正方形被木乃伊的正方形完全覆盖住了,则自己无处可逃。

那难道就没有可能自己在中途被木乃伊抓住吗?不妨考虑逆推。

首先我们可以认同的是如果一个格子在\(mid\)时安全,那么它的八联通格子在\(mid-1\)的时间都安全。那么在\(mid\)时对于某个安全格子,它的八联通格子在\(mid-1\)时都是可以落脚的,而且这个格子还要能在\(mid-1\)时到达,这个格子必然存在。那么我们通过不断逆推,即可找到走过来的安全路径。

时间复杂度\(O(n\log^2 n)\)

关于细节实现上要多做一点优化,免得TLE。

Code

#include <algorithm>
#include <cstdio>
#define pushup(rt) sum[rt]=(cnt[rt]?(r-l+1):(sum[rt<<1]+sum[rt<<1|1]))
using namespace std;
typedef long long ll;
const int maxn=4000010;
template <typename Tp> inline int getmin(Tp &x,Tp y){return y<x?x=y,1:0;}
template <typename Tp> inline int getmax(Tp &x,Tp y){return y>x?x=y,1:0;}
template <typename Tp> inline void read(Tp &x)
{
x=0;int f=0;char ch=getchar();
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-') f=1,ch=getchar();
while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar();
if(f) x=-x;
}
struct vec{
int x,y;
bool operator < (const vec &b)const{return x<b.x;}
}p[maxn];
int z,n,m,MX,sum[maxn<<2],cnt[maxn<<2];
int abs(int x){return x<0?-x:x;}
void update(int l,int r,int L,int R,int val,int rt)
{
if(L<=l&&r<=R){cnt[rt]+=val;pushup(rt);return ;}
int m=(l+r)>>1;
if(L<=m) update(l,m,L,R,val,rt<<1);
if(m<R) update(m+1,r,L,R,val,rt<<1|1);
pushup(rt);
}
int query(int l,int r,int L,int R,int rt)
{
if(cnt[rt]) return min(R,r)-max(L,l)+1;
if(L<=l&&r<=R) return sum[rt];
int m=(l+r)>>1,res=0;
if(L<=m) res+=query(l,m,L,R,rt<<1);
if(m<R) res+=query(m+1,r,L,R,rt<<1|1);
return res;
}
int cross(int id,int dis)
{
if(p[id].y-dis>dis||p[id].y+dis<-dis) return 0;
return 1;
}
int check(int x)
{
int s=1,t,res=0,lst=0;
while(p[s].x+x<-x) s++;t=s;
for(int i=-x;i<=x;i++)
{
while(s<=n&&p[s].x-x<=i)
{
if(cross(s,x))
{
lst=-1;
update(-MX,MX,p[s].y-x,p[s].y+x,1,1);
}
++s;
}
while(t<=n&&p[t].x+x<i)
{
if(cross(t,x))
{
lst=-1;
update(-MX,MX,p[t].y-x,p[t].y+x,-1,1);
}
++t;
}
if(~lst) continue;
lst=query(-MX,MX,-x,x,1);
if(lst<(x<<1|1)){res=1;break;}
}
while(t<s)
{
if(cross(t,x)) update(-MX,MX,p[t].y-x,p[t].y+x,-1,1);
++t;
}
return res;
}
int input()
{
read(n);
if(n==-1) return 0;
int res=0;MX=0;
for(int i=1;i<=n;i++)
{
read(p[i].x);read(p[i].y);
getmax(MX,abs(p[i].y));
getmax(res,abs(p[i].x));
}
getmax(res,MX);MX+=res;
sort(p+1,p+n+1);
return res;
}
int main()
{
int L,R,mid,ans;
while((R=input())||(~n))
{
L=1;ans=-1;
while(L<=R)
{
mid=(L+R)>>1;
if(!check(mid)) R=mid-1,ans=mid;
else L=mid+1;
}
if(~ans) printf("Case %d: %d\n",++z,ans);
else printf("Case %d: never\n",++z);
}
return 0;
}

BZOJ 3958 Mummy Madness的更多相关文章

  1. 【BZOJ 3958】 3958: [WF2011]Mummy Madness (二分+扫描线、线段树)

    3958: [WF2011]Mummy Madness Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 96  Solved: 41 Descripti ...

  2. 【BZOJ3958】[WF2011]Mummy Madness 二分+扫描线+线段树

    [BZOJ3958][WF2011]Mummy Madness Description 在2011年ACM-ICPC World Finals上的一次游览中,你碰到了一个埃及古墓. 不幸的是,你打开了 ...

  3. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  4. WorldFinal11 (2/11)

    WorldFinal 11 Trash Removal 题意 给你一个多边形,问这个多边形至少需要多宽的长度,才能把这个多边形放进去. 数据范围100 题解 数据范围只有100,暴力枚举两点,然后算最 ...

  5. BZOJ 2127: happiness [最小割]

    2127: happiness Time Limit: 51 Sec  Memory Limit: 259 MBSubmit: 1815  Solved: 878[Submit][Status][Di ...

  6. BZOJ 3275: Number

    3275: Number Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 874  Solved: 371[Submit][Status][Discus ...

  7. BZOJ 2879: [Noi2012]美食节

    2879: [Noi2012]美食节 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1834  Solved: 969[Submit][Status] ...

  8. bzoj 4610 Ceiling Functi

    bzoj 4610 Ceiling Functi Description bzoj上的描述有问题 给出\(n\)个长度为\(k\)的数列,将每个数列构成一个二叉搜索树,问有多少颗形态不同的树. Inp ...

  9. BZOJ 题目整理

    bzoj 500题纪念 总结一发题目吧,挑几道题整理一下,(方便拖板子) 1039:每条线段与前一条线段之间的长度的比例和夹角不会因平移.旋转.放缩而改变,所以将每条轨迹改为比例和夹角的序列,复制一份 ...

随机推荐

  1. UVALive - 4975_Casting Spells

    题意很简单,给你一个字符串,要求你求出一个最长的形似于w(wr)w(wr)的最长连续子串的长度.wr表示w的逆序串. 在这里大家很容易就能想到Manacher算法求回文串.没有错,就是这个. 算法的详 ...

  2. AtCoder Grand Contest 019 A: Ice Tea Store

    tourist出的题诶!想想就很高明,老年选手可能做不太动.不过A题还是按照惯例放水的. AtCoder Grand Contest 019 A: Ice Tea Store 题意:买0.25L,0. ...

  3. BZOJ5333 [Sdoi2018]荣誉称号 【差分 + 树形dp】

    题目链接 BZOJ5333 题解 看到式子,立即想到二叉树上一个点及其\(k\)个父亲权值和[如果有的话]模\(m\)意义下为\(0\) 考虑如何满足条件 我们假设\(1\)号为第\(0\)层 那么我 ...

  4. bzoj2314: 士兵的放置(树形DP)

    0表示被父亲控制,1表示被儿子控制,2表示被自己控制.f表示最少士兵数,g表示方案数. 转移贼难写,写了好久之后写不下去了,看了一眼题解,学习了...原来还可以这么搞 比如求f[i][1]的时候,要在 ...

  5. poj3421 X-factor Chains

    X-factor Chains Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7733   Accepted: 2447 D ...

  6. Land of Farms HDU - 5556 二分图匹配

    Farmer John and his brothers have found a new land. They are so excited and decide to build new farm ...

  7. mysql ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO)错误解决办法

    我的电脑是win10,所用的是mysql5.7.14 近期在学习mysql数据库的时候,遇到了这个错误,我的密码错误了.突如其来的问题,很是蒙蔽,因为我没对数据库设置过密码.通过网上查询,可以通过进入 ...

  8. fisher's exact test

    sklearn实战-乳腺癌细胞数据挖掘(博主亲自录视频) https://study.163.com/course/introduction.htm?courseId=1005269003&u ...

  9. string的内存本质

    虽然没有研究过string的源代码,不过可以确定的是string的内存空间是在堆上开辟的,它自己负责释放空间,不用我们关系. 我们用一个动态分配的字符串指针初始化一个string对象retStr,它会 ...

  10. 关于java 获取 html select标签 下拉框 option 文本内容 隐藏域

    在HTML中从多选下拉框中提取已选中选项的文本内容到后台,被这个问题难倒了. demo.jsp文件 <select id="selecttype" name"typ ...