[BZOJ1189][HNOI2007]紧急疏散evacuate(bfs+二分+最大流)

该博客详细介绍了如何利用BFS求解最短距离,结合二分查找与最大流算法解决紧急疏散问题。通过BFS计算每个门到各个点的最短距离,然后在二分查找中结合最大流判断在给定时间内能否完成疏散。
摘要由CSDN通过智能技术生成

题目描述

传送门

题解

首先bfs得出每个门到每个点的最短距离dis。
二分最短时间+最大流判定。
如何判定?
假设二分到mid的时间,对于每个空地I,s->I,1,对于每一个门I,I->t,mid;
在这两排点的中间需要再加一排点,是把每一个门拆成mid个得到的,每个表示某个人用了某些时间到达了这个门。那么显然,对于某一个人i,某个门j,如果dis[i][j] < <script type="math/tex" id="MathJax-Element-65"><</script>mid,那么i->j_dis[i][j],1;
最后对于每一个门拆成的点i_j,i_j->I,mid-j+1,这一步表示在j这个时间到达了i这个门的人只有mid-j+1个人可以通过。
大概长这个样子:
这里写图片描述

代码

#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std;
const int max_n=25;
const int max_N=1e5+5;
const int max_m=1e6+5;
const int max_e=max_m*2;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值