Description

windy有一块矩形土地,被分为 N*M 块 1*1 的小格子。 有的格子含有障碍物。 如果从格子A可以走到格子B,那么两个格子的距离就为两个格子中心的欧几里德距离。 如果从格子A不可以走到格子B,就没有距离。 如果格子X和格子Y有公共边,并且X和Y均不含有障碍物,就可以从X走到Y。 如果windy可以移走T块障碍物,求所有格子间的最大距离。 保证移走T块障碍物以后,至少有一个格子不含有障碍物。

Input

输入文件maxlength.in第一行包含三个整数,N M T。 接下来有N行,每行一个长度为M的字符串,'0'表示空格子,'1'表示该格子含有障碍物。

Output

输出文件maxlength.out包含一个浮点数,保留6位小数。

Sample Input

【输入样例一】
3 3 0
001
001
110

【输入样例二】
4 3 0
001
001
011
000

【输入样例三】
3 3 1
001
001
001

Sample Output

【输出样例一】
1.414214

【输出样例二】
3.605551

【输出样例三】
2.828427

HINT

20%的数据,满足 1 <= N,M <= 30 ; 0 <= T <= 0 。 40%的数据,满足 1 <= N,M <= 30 ; 0 <= T <= 2 。 100%的数据,满足 1 <= N,M <= 30 ; 0 <= T <= 30 。


题目大意

  一个$N \times M$的网格上有些格子是障碍。如果两个非障碍格子四连通,那么定义它们之间的距离为他们的欧几里德距离,否则它们没有距离。

  现在你可以把其中的$T$个障碍格子变为非障碍格子,然后问,操作后中有距离的点对中最长的距离是多少。

  由于$N, M$数据范围小到爆,所以可以直接枚举从哪个格子开始清理障碍格子,用最短路算法跑出到每个格子最少清楚的障碍格子数,然后暴力枚举所有可行的格子,计算它和当前枚举的格子的欧几里德距离,然后更新答案。

Code

 /**
* bzoj
* Problem#1295
* Accepted
* Time: 724ms
* Memory: 1312k
*/
#include <bits/stdc++.h>
using namespace std; typedef bool boolean;
#define pii pair<int, int>
#define fi first
#define sc second const int N = ; int n, m, k;
int val[N][N];
int f[N][N];
boolean vis[N][N];
int ans = ;
char str[N]; inline void init() {
scanf("%d%d%d", &n, &m, &k);
for (int i = ; i < n; i++) {
scanf("%s", str);
for (int j = ; j < m; j++)
val[i][j] = str[j] - '';
}
} const int mov[][] = {{, }, {-, }, {, }, {, -}}; queue<pii> que;
void spfa(pii s) {
memset(f, 0x3f, sizeof(f));
que.push(s);
f[s.fi][s.sc] = val[s.fi][s.sc];
while (!que.empty()) {
pii e = que.front();
que.pop();
vis[e.fi][e.sc] = false;
for (int d = ; d < ; d++) {
pii eu (e.fi + mov[d][], e.sc + mov[d][]);
if (eu.fi < || eu.fi >= n || eu.sc < || eu.sc >= m)
continue;
if (f[e.fi][e.sc] + val[eu.fi][eu.sc] < f[eu.fi][eu.sc]) {
f[eu.fi][eu.sc] = f[e.fi][e.sc] + val[eu.fi][eu.sc];
if (!vis[eu.fi][eu.sc]) {
vis[eu.fi][eu.sc] = true;
que.push(eu);
}
}
}
}
} inline void solve() {
for (int i = ; i < n; i++)
for (int j = ; j < m; j++) {
spfa(pii(i, j));
for (int x = ; x < n; x++)
for (int y = ; y < m; y++) {
if (f[x][y] <= k)
ans = max(ans, (x - i) * (x - i) + (y - j) * (y - j));
}
}
printf("%.6lf\n", sqrt((double)ans));
} int main() {
init();
solve();
return ;
}

bzoj 1295 最长距离 - 最短路的更多相关文章

  1. BZOJ 1295 最长距离 BFS+枚举

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1295 题目大意: windy有一块矩形土地,被分为 N*M 块 1*1 的小格子. 有 ...

  2. BZOJ 1295: [SCOI2009]最长距离( 最短路 )

    把障碍点看做点(边)权为1, 其他为0. 对于每个点跑spfa, 然后和它距离在T以内的就可以更新答案 ------------------------------------------------ ...

  3. bzoj 1295: [SCOI2009]最长距离 暴力+bfs最短路

    题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=1295 题解: 对每个点暴力跑一遍bfs,看能够到达的最远位置,这里如果有障碍物则距离为1 ...

  4. BZOJ 1295: [SCOI2009]最长距离 spfa

    1295: [SCOI2009]最长距离 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1295 Description windy有一块 ...

  5. bzoj 1295: [SCOI2009]最长距离

    题目链接 1295: [SCOI2009]最长距离 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1165  Solved: 619[Submit][ ...

  6. [BZOJ 1295][SCOI2009]最长距离(SPFA+暴力)

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1295 分析:很巧妙的一道spfa从搜索的角度是搜索在所有1中搜索删除哪T个1,对整个图询问,这 ...

  7. 【BZOJ 1295】 [SCOI2009]最长距离

    Description windy有一块矩形土地,被分为 N*M 块 1*1 的小格子. 有的格子含有障碍物. 如果从格子A可以走到格子B,那么两个格子的距离就为两个格子中心的欧几里德距离. 如果从格 ...

  8. bzoj 1295 1295: [SCOI2009]最长距离

    思路:对于每个点出发bfs做一次dp, dp[ i ][ j ][ k ] 表示从枚举的该点能不能经过k个障碍物到达(i , j). #include<bits/stdc++.h> #de ...

  9. [BZOJ1295][SCOI2009]最长距离 最短路+枚举

    1295: [SCOI2009]最长距离 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1683  Solved: 912[Submit][Statu ...

随机推荐

  1. 虚拟机 liunx系统以 root 身份登录权限

    开启虚拟机 打开终端开启root账户 :sudo passwd -u root 输入当前用户的密码   为root账户设置密码:sudo passwd root 设置root密码,输入两次   测试r ...

  2. ASP.NET Core 启动流程图

    简洁描述: 一   WebHostBuilder.Build() =>1注入公共的实例 2创建WebHost实例 3注入自定义实例 4创建IServer 5添加中间件(_components集合 ...

  3. C# 深拷贝和浅拷贝

    在编码中.经常会遇到赋值操作.值类型就不说了.如果是引用类型赋值.其实是引用传递,即赋值的是一个引用.比如: Person p1 = new Person("张三", " ...

  4. unity3d连接Sqlite并打包发布Android

    连接Sqlite首先要把dll程序集导入到unity3d工程里面.安装好的unity中可以找到

  5. linux 下安装mysql-5.7.12-1.el6.x86_64.rpm-bundle.tar

    -rw-rw-r--. hadoop hadoop Nov : mysql--.el6.x86_64.rpm-bundle.tar tar -xvf mysql-5.7.12-1.el6.x86_64 ...

  6. sql server2012 远程访问设置(转)

    转自:http://blog.csdn.net/xiadingling/article/details/8215282 步骤 打开SQL server2012,使用windows身份登录   登录后, ...

  7. [Unit Test] Unit Test Brief Introduction

    Levels of Testing- Acceptance- Performance- Functional- Integration- Unit Why Unit Testing- Feedback ...

  8. windows8安装msi或exe软件提示2503错误的解决办法

    windows8以后的版本安装msi软件(比如nodejs.msi.Git.msi.python.msi.T ortoiseSVN.msi)的时候老师出现2503.2502的错误,究其原因还是系统权限 ...

  9. 20155228 2016-2017-2 《Java程序设计》第1周学习总结

    20155228 2016-2017-2 <Java程序设计>第1周学习总结 教材学习内容总结 这部分内容是以教材为基础,根据个人的理解来描述的,有的地方的理解和表述可能不规范甚至不正确, ...

  10. Ngine X 完全开发指南 读书笔记-前言

    一开始接触的编程语言是VF,那是一种可视化编程语言,所谓的可视化,就是运行结果能直接看得到的,非常直观,便于调试,适合刚刚接触编程的新人学习.当时学得懵懂,半知半解,就是感觉程序非常神奇,常常几句代码 ...