给出数字N(1<=N<=10000),X(1<=x<=1000),Y(1<=Y<=1000),代表有N个敌人分布一个X行Y列的矩阵上,矩形的行号从0到X-1,列号从0到Y-1再给出四个数字x1,y1,x2,y2,代表你要从点(x1,y1)移到(x2,y2)。在移动的过程中你当然希望离敌人的距离的最小值最大化,现在请求出这个值最大可以为多少,以及在这个前提下,你最少要走多少步才可以回到目标点。注意这里距离的定义为两点的曼哈顿距离,即某两个点的坐标分为(a,b),(c,d),那么它们的距离为|a-c|+|b-d|。

输入:

第一行给出数字N,X,Y

第二行给出x1,y1,x2,y2

下面将有N行,给出N个敌人所在的坐标

输出:

在一行内输出你离敌人的距离及在这个距离的限制下,你回到目标点最少要移动多少步。

Sample input

2 5 6

0 0 4 0

2 1

2 3

Sample output

2 14

/*
先预处理出每个点与距离它最近的敌人的距离,然后二分+BFS
我的预处理貌似写麻烦了,但是比标程快一秒,嘿嘿……
*/
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#define N 10010
#define M 1010
using namespace std;
int dis[M][M],p,n,m,x1,y1,x2,y2;
int qx[M*M],qy[M*M],step[M][M],vis[M][M],head,tail;
int ax[]={,,,-};
int ay[]={,-,,};
struct node
{
int x,y;
};node a[N];
bool check(int limit)
{
if(dis[x1][y1]<limit)return false;
memset(step,0x3f3f3f3f,sizeof(step));
memset(vis,,sizeof(vis));
head=;tail=;
qx[]=x1;qy[]=y1;step[x1][y1]=;vis[x1][y1]=;
while(head<tail)
{
++head;int x=qx[head],y=qy[head];
if(x==x2&&y==y2)break;
for(int i=;i<;i++)
{
int xx=x+ax[i],yy=y+ay[i];
if(xx>=&&xx<=n&&yy>=&&yy<=m&&!vis[xx][yy]&&dis[xx][yy]>=limit)
{
++tail;
qx[tail]=xx;
qy[tail]=yy;
step[xx][yy]=step[x][y]+;
vis[xx][yy]=;
}
}
}
if(step[x2][y2]<)return true;
else return false;
}
void init()
{
memset(dis,0x3f3f3f3f,sizeof(dis));
for(int t=;t<=p;t++)
{
int x=a[t].x,y=a[t].y;
for(int i=x;i>=;i--)
{
if(dis[i][y]<=abs(x-i))break;
for(int j=y;j>=;j--)
{
if(dis[i][j]<=(abs(x-i)+abs(y-j)))break;
dis[i][j]=abs(x-i)+abs(y-j);
}
}
for(int i=x+;i<=n;i++)
{
if(dis[i][y]<=abs(x-i))break;
for(int j=y;j>=;j--)
{
if(dis[i][j]<=(abs(x-i)+abs(y-j)))break;
dis[i][j]=abs(x-i)+abs(y-j);
}
}
for(int i=x;i>=;i--)
{
if(dis[i][y+]<=abs(x-i))break;
for(int j=y+;j<=m;j++)
{
if(dis[i][j]<=(abs(x-i)+abs(y-j)))break;
dis[i][j]=abs(x-i)+abs(y-j);
}
}
for(int i=x+;i<=n;i++)
{
if(dis[i][y+]<=abs(x-i))break;
for(int j=y+;j<=m;j++)
{
if(dis[i][j]<=(abs(x-i)+abs(y-j)))break;
dis[i][j]=abs(x-i)+abs(y-j);
}
}
}
}
int main()
{
//freopen("jh.in","r",stdin);
freopen("escape.in","r",stdin);
freopen("escape.out","w",stdout);
scanf("%d%d%d%d%d%d%d",&p,&n,&m,&x1,&y1,&x2,&y2);
x1++;y1++;x2++;y2++;
for(int i=;i<=p;i++)
{
scanf("%d%d",&a[i].x,&a[i].y);
a[i].x++;a[i].y++;
}
init();
int l=,r=n*m,ans1,ans2;
while(l<=r)
{
int mid=(l+r)/;
if(check(mid))
{
ans1=mid;
ans2=step[x2][y2];
l=mid+;
}
else r=mid-;
}
printf("%d %d",ans1,ans2);
return ;
}

大逃亡(escape.*)的更多相关文章

  1. HDU 3533 Escape(大逃亡)

    HDU 3533 Escape(大逃亡) /K (Java/Others)   Problem Description - 题目描述 The students of the HEU are maneu ...

  2. hdu.1429.胜利大逃亡(续)(bfs + 0101011110)

    胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  3. 胜利大逃亡[HDU1253]

    胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  4. hdu 1429 胜利大逃亡(续)

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1429 胜利大逃亡(续) Description Ignatius再次被魔王抓走了(搞不懂他咋这么讨魔王 ...

  5. Hdu 1429 胜利大逃亡(续) 分类: Brush Mode 2014-08-07 17:01 92人阅读 评论(0) 收藏

    胜利大逃亡(续) Time Limit : 4000/2000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Subm ...

  6. HDOJ 1429 胜利大逃亡(续)

    胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  7. hdu 1429 胜利大逃亡(续)(bfs+位压缩)

    胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  8. hdoj 1253 胜利大逃亡

    胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  9. HDU-1253 胜利大逃亡 (BFS)

    此题可以做为三维深搜模板题.. 胜利大逃亡 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Ot ...

随机推荐

  1. C# MySql Select

    MySqlCommand objCmd = new MySqlCommand("select * from `main_db`.`t_realdailyinfo` ", objCo ...

  2. [App Store Connect帮助]三、管理 App 和版本(2.2)输入 App 信息:设置 App 分级

    您必须设置 App 分级,这是一项平台版本信息属性,用于在 App Store 上实施家长控制.App Store Connect 提供了一份内容描述列表,通过该列表,您可以确定相应内容在您 App ...

  3. [Swift通天遁地]五、高级扩展-(1)快速检测设备属性:版本、类型、屏幕尺寸

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  4. Vue.js经典开源项目汇总-前端参考资源

    Vue.js经典开源项目汇总 原文链接:http://www.cnblogs.com/huyong/p/6517949.html Vue是什么? Vue.js(读音 /vjuː/, 类似于 view) ...

  5. Effective C++ 深入理解inline

    Effective C++ 深入理解inline inline语义 inline本义是将所调用函数用自身的函数本体替换之,免受函数调用所招致的额外开销,比宏还要不易出错:但是实际上inline的受编译 ...

  6. jQueryTools-Scrollable.js

    转载一篇例子,学习使用: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http: ...

  7. 基于Android SDK安装PhoneGap框架

    下载zip文件PhoneGap 2.0.0 PhoneGap 2.0.0 Released 20 Jul 2012http://phonegap.com/download/ 解压缩后的目录结构:Dir ...

  8. Codeforces 766E

    题意:给一棵树(1e5),每个节点上有对应权值(0<=ai<=1e6)定义树上两个节点间的距离为路径中节点的异或,求所有节点对间的距离和(包括节点自身也作为节点对,距离为节点权值). 解题 ...

  9. ACM_黑色星期五

    黑色星期五 Time Limit: 2000/1000ms (Java/Others) Problem Description: 13号又是星期五是一个不寻常的日子吗?13号在星期五比在其他日少吗?为 ...

  10. form表单中图片也可以当作提交按钮

    点击图片按钮时,不光提交其他输入框信息,还把鼠标点击图片上的x,y坐标也传输过去了