[题目链接]

https://www.lydsy.com/JudgeOnline/problem.php?id=1189

[算法]

首先 , 答案具有单调性 , 不妨二分答案” 第mid秒是否可以完成疏散 ”

检验时 , 首先通过广度优先搜索BFS求出每扇门到每个空地的距离

然后建图 , 判断最大流是否等于空地的数量

详见代码

时间复杂度: O(dinic(N ^ 3 , N ^ 3) log N ^ 2)

[代码]

#include<bits/stdc++.h>
using namespace std;
#define MAXN 16100
#define MAXD 25
const int inf = 2e9;
const int dx[] = { , , - , };
const int dy[] = {- , , , }; struct edge
{
int to , w , nxt;
} e[MAXN << ]; int tot , cntk , cntd , S , T , n , m;
int head[MAXN] , depth[MAXN];
int point[MAXD][MAXD];
int dist[MAXN][MAXD][MAXD];
char mp[MAXD][MAXD];
pair<int , int> a[MAXN * MAXD]; template <typename T> inline void chkmax(T &x,T y) { x = max(x,y); }
template <typename T> inline void chkmin(T &x,T y) { x = min(x,y); }
template <typename T> inline void read(T &x)
{
T f = ; x = ;
char c = getchar();
for (; !isdigit(c); c = getchar()) if (c == '-') f = -f;
for (; isdigit(c); c = getchar()) x = (x << ) + (x << ) + c - '';
x *= f;
}
inline void addedge(int u , int v , int w)
{
++tot;
e[tot] = (edge){v , w , head[u]};
head[u] = tot;
++tot;
e[tot] = (edge){u , , head[v]};
head[v] = tot;
}
inline bool valid(int x , int y)
{
return x >= && x <= n && y >= && y <= m;
}
inline void do_bfs(int s)
{
queue< pair<int , int> > q;
q.push(make_pair(a[s].first , a[s].second));
memset(dist[s] , 0x3f , sizeof(dist[s]));
dist[s][a[s].first][a[s].second] = ;
while (!q.empty())
{
pair<int , int> cur = q.front();
q.pop();
for (int i = ; i < ; i++)
{
int nx = cur.first + dx[i] , ny = cur.second + dy[i];
if (valid(nx , ny) && mp[nx][ny] == '.')
{
if (dist[s][cur.first][cur.second] + < dist[s][nx][ny])
{
dist[s][nx][ny] = dist[s][cur.first][cur.second] + ;
q.push(make_pair(nx , ny));
}
}
}
}
}
inline bool bfs()
{
int l , r;
static int q[MAXN];
q[l = r = ] = S;
memset(depth , ,sizeof(depth));
depth[S] = ;
while (l <= r)
{
int cur = q[l++];
for (int i = head[cur]; i; i = e[i].nxt)
{
int v = e[i].to , w = e[i].w;
if (w > && !depth[v])
{
depth[v] = depth[cur] + ;
q[++r] = v;
if (v == T) return true;
}
}
}
return false;
}
inline int dinic(int u , int flow)
{
int rest = flow , ret = ;
if (u == T) return flow;
for (int i = head[u]; i && rest; i = e[i].nxt)
{
int v = e[i].to , w = e[i].w;
if (depth[v] == depth[u] + && w)
{
int k = dinic(v , min(rest , w));
if (!k) depth[v] = ;
e[i].w -= k;
e[i ^ ].w += k;
rest -= k;
}
}
return flow - rest;
}
inline bool check(int mid)
{
S = cntk + cntd * mid + cntd + ;
T = S + ;
tot = ;
for (int i = ; i <= T; i++) head[i] = ;
for (int i = ; i <= n; i++)
{
for (int j = ; j <= m; j++)
{
if (mp[i][j] == '.')
addedge(S , point[i][j] , );
}
}
for (int i = ; i <= cntd; i++)
{
for (int j = ; j <= n; j++)
{
for (int k = ; k <= m; k++)
{
if (mp[j][k] == '.' && dist[i][j][k] <= mid)
addedge(point[j][k] , cntk + (i - ) * mid + dist[i][j][k] , );
}
}
}
for (int i = ; i <= cntd; i++)
{
for (int j = ; j <= mid; j++)
{
addedge(cntk + (i - ) * mid + j , cntk + cntd * mid + i , mid - j + );
}
}
for (int i = ; i <= cntd; i++) addedge(cntk + cntd * mid + i , T , mid);
int ret = ;
while (bfs())
{
while (int flow = dinic(S , inf)) ret += flow;
}
return ret == cntk;
} int main()
{ scanf("%d%d" , &n , &m);
for (int i = ; i <= n; i++) scanf("%s" , mp[i] + );
for (int i = ; i <= n; i++)
{
for (int j = ; j <= m; j++)
{
if (mp[i][j] == '.')
point[i][j] = ++cntk;
if (mp[i][j] == 'D') a[++cntd] = make_pair(i , j);
}
}
for (int i = ; i <= cntd; i++) do_bfs(i);
int l = , r = n * m , ans = -;
while (l <= r)
{
int mid = (l + r) >> ;
if (check(mid))
{
ans = mid;
r = mid - ;
} else l = mid + ;
}
if (ans >= ) printf("%d\n" , ans);
else printf("impossible\n"); return ; }

[HNOI 2007] 紧急疏散的更多相关文章

  1. 博弈论(SG函数):HNOI 2007 分裂游戏

    Description 聪聪和睿睿最近迷上了一款叫做分裂的游戏. 该游戏的规则试: 共有 n 个瓶子, 标号为 0,1,2.....n-1, 第 i 个瓶子中装有 p[i]颗巧克力豆,两个人轮流取豆子 ...

  2. Solution -「HNOI 2007」「洛谷 P3185」分裂游戏

    \(\mathcal{Description}\)   Link.   给定 \(n\) 堆石子,数量为 \(\{a_n\}\),双人博弈,每轮操作选定 \(i<j\le k\),使 \(a_i ...

  3. [插头DP自我总结]

    [HNOI 2007]神奇游乐园 #include <bits/stdc++.h> #define maxn 110 using namespace std; typedef long l ...

  4. [HNOI2007]紧急疏散EVACUATE (湖南2007年省选)

    [HNOI2007]紧急疏散EVACUATE 题目描述 发生了火警,所有人员需要紧急疏散!假设每个房间是一个N M的矩形区域.每个格子如果是'.',那么表示这是一块空地:如果是'X',那么表示这是一面 ...

  5. poi读取excel模板,填充内容并导出,支持导出2007支持公式自动计算

    /** * 版权所有(C) 2016 * @author www.xiongge.club * @date 2016-12-7 上午10:03:29 */ package xlsx; /** * @C ...

  6. BZOJ 2007: [Noi2010]海拔

    2007: [Noi2010]海拔 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2410  Solved: 1142[Submit][Status] ...

  7. 开源WinForms界面开发框架Management Studio 选项卡文档 插件 Office 2007蓝色风格 后台线程

    Management Studio是我在WinForms小项目开发过程中搭建起来的一个插件式结构的应用程序框架,因为简单灵活又容易扩展,现在将它开源供读者参考. 跑起来的效果图如下所示,具备选项卡式多 ...

  8. win7下wndows virtual pc 2007 装xp比新版本的 Windows virtual pc 好用

    2007下装xp虚拟机启动快,支持拖放.

  9. [SharePoint 2007/2010]Query SharePoint Calendar Event

    首先要搞清楚日历事件的各种类型,参考文章: http://sharepoint.microsoft.com/blog/Pages/BlogPost.aspx?PageType=4&ListId ...

随机推荐

  1. 72.spring boot讨论群【从零开始学Spring Boot】

    [从零开始学习Spirng Boot-常见异常汇总] 如果您碰到什么问题,您可以加群进行探讨,在群里有加入的都是Spring Boot志同道合的朋友: Spring Boot QQ交流群:193341 ...

  2. PTA 02-线性结构4 Pop Sequence (25分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/665 5-3 Pop Sequence   (25分) Given a stack wh ...

  3. [Go]链表的相关知识

    切片有着占用内存少喝创建便捷等特点,但它本质上还是数组.切片的一大好处是可以通过窗口快速地定位并获取或者修改底层数组中的元素.不过当删除切片中的元素的时候就没那么简单了.元素复制一般是免不了的,就算只 ...

  4. 【POJ3311】Hie with the Pie(状压DP,最短路)

    题意: 思路:状压DP入门题 #include<cstdio> #include<cstdlib> #include<algorithm> #include< ...

  5. isNaN+parseFloat进行统计以及对NaN的处理【JS验证数字】

    今天遇到这么一个需求: 对数据进行统计,可是在统计的时候parseFloat的时候出来一个NaN.后来用isNaN判断,如果是NaN,就给其设置一个初值. 先看对两个方法的解释 parseFloat: ...

  6. OC-category 为什么不能添加成员变量

    以下的答案是百度的,仅做记录而已: 1. 利用运行时实际上也不是添加成员变量.已编译的类的内存布局是不变的,Class就是一个结构体,里面的成员不能改变.但是通过运行时可以将一个对象或基础类型变成指定 ...

  7. CF821E(多次矩阵快速幂)

    题意: 冈伦从二维平面上(0,0)走到(k,0),(k<=1e18),每次有三个行动方向:右上一格.右方一格.右下一格,问一共有多少种走的方案 限制:每段x都有一个天花板,一共有n段天花板(n& ...

  8. 如何使用eclipse for c/c++ 配置环境编写第一个C程序

    因为VS太大还要安装太多的插件,,,所以想用eclipse编写C语言... 1.下载eclipse for c/c++版本  去官网即可下载   https://www.eclipse.org/dow ...

  9. java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet

    新建Maven 项目的时候报错: java.lang.ClassNotFoundException: org.springframework.web.servlet.DispatcherServlet ...

  10. 使用图像扫描控件ScanOnWeb实现在线图像扫描

    今天上网查资料,看到一篇文章,描述的是一个开发OA软件的公司解决浏览器嵌入式扫描仪编程的文章,文章描述了改OA厂商的工程师如何辛苦的克服了各种技术难题,最终实现了在线图像扫描处理,然后又在无数个不眠的 ...