题目链接

题意

给定一张网格,格子中有些地方有柱子,有些柱子上面有蜥蜴。

每个柱子只能承受有限只蜥蜴从上面经过。每只蜥蜴每次能走到相距曼哈顿距离\(\leq k\)的格子中去。

问有多少只蜥蜴能走出网格。

分析

参考博文

拆点

因为这道题中的容量不是限制在边上,而是限制在点上的,所以可以考虑将一个点拆成两个点,中间再加一条边,边的容量即为原先点上的值。

想法很重要。

建图

  1. 对于起始有蜥蜴的点,从源点\(s\)连一条容量为\(1\)的边到它;

  2. 对于中间点,拆成两点:点\(1\)到点\(2\)的容量为点的承受值;点\(2\)再代表原先的该点向外连向其他点,权值可以赋为大于等于容量的任意值;

  3. 对于可以直接跳出去的点,向汇点\(e\)连一条边,容量为该点的承受值。

跑最大流

Code

#include <bits/stdc++.h>
#define maxn 1010
#define maxp 1010
#define inf 0x3f3f3f3f
#define id1(i,j) (idx(i,j)<<1)
#define id2(i,j) (id1(i,j)|1)
using namespace std;
typedef long long LL;
int dep[maxp], cur[maxp], n, m, tot, k, ne[maxp];
char cnt[maxn][maxn], s[maxn];
inline int idx(int i, int j) { return (i-1)*m+j; }
inline bool check(int i, int j) { return i > 0 && i <= n && j > 0 && j <= m && cnt[i][j]!='0'; }
struct Edge { int to, ne, c; }edge[maxp<<4];
void add(int u, int v, int c) {
edge[tot] = {v, ne[u], c};
ne[u] = tot++;
edge[tot] = {u, ne[v], 0};
ne[v] = tot++;
}
void init() {
tot = 0; memset(ne, -1, sizeof(ne));
for (int i = 1; i <= n; ++i) {
for (int j = 1; j <= m; ++j) {
if (cnt[i][j] == '0') continue;
if (i-k <= 0 || i+k > n || j-k <= 0 || j+k > m) { add(id1(i,j), 1, cnt[i][j]-'0'); continue; }
add(id1(i,j), id2(i,j), cnt[i][j]-'0');
for (int r = i-k; r <= i+k; ++r) {
for (int c = j-k; c <= j+k; ++c) {
if (abs(i-r)+abs(j-c) > k) continue;
if (check(r, c)) add(id2(i, j), id1(r, c), inf);
}
}
}
}
}
int bfs(int src) {
queue<int> q;
while (!q.empty()) q.pop();
memset(dep, 0, sizeof(dep));
dep[src] = 1;
q.push(src);
while (!q.empty()) {
int u = q.front(); q.pop();
for (int i = ne[u]; ~i; i = edge[i].ne) {
int v = edge[i].to;
if (edge[i].c > 0 && !dep[v]) {
dep[v] = dep[u]+1;
q.push(v);
}
}
}
return dep[1];
}
int dfs(int u, int flow) {
if (u == 1) return flow;
for (int& i = cur[u]; ~i; i = edge[i].ne) {
int v = edge[i].to;
if (edge[i].c > 0 && dep[v]-dep[u]==1) {
int c = dfs(v, min(flow, edge[i].c));
if (c) {
edge[i].c -= c;
edge[i^1].c += c;
return c;
}
}
}
return 0;
}
int kas;
void work() {
scanf("%d%d", &n, &k);
for (int i = 1; i <= n; ++i) {
scanf("%s", cnt[i]+1);
}
m = strlen(cnt[1]+1);
init(); int all = 0;
for (int i = 1; i <= n; ++i) {
scanf("%s", s+1);
for (int j = 1; j <= m; ++j) {
if (s[j] == 'L') ++all, add(0, id1(i,j), 1);
}
} int pcnt = id2(n, m)+1, ans=0, ret;
while (bfs(0)) {
for (int i = 0; i < pcnt; ++i) cur[i] = ne[i];
while (ret = dfs(0, inf)) ans += ret;
}
ans = all-ans;
printf("Case #%d: ", ++kas);
if (!ans) puts("no lizard was left behind.");
else if (ans==1) puts("1 lizard was left behind.");
else printf("%d lizards were left behind.\n", ans);
}
int main() {
int T;
scanf("%d", &T);
while (T--) work();
return 0;
}

hdu 2732 Leapin' Lizards 最大流 拆点 建图的更多相关文章

  1. hdu 2732 Leapin' Lizards (最大流 拆点建图)

    Problem Description Your platoon of wandering lizards has entered a strange room in the labyrinth yo ...

  2. POJ 2711 Leapin' Lizards / HDU 2732 Leapin' Lizards / BZOJ 1066 [SCOI2007]蜥蜴(网络流,最大流)

    POJ 2711 Leapin' Lizards / HDU 2732 Leapin' Lizards / BZOJ 1066 [SCOI2007]蜥蜴(网络流,最大流) Description Yo ...

  3. HDU - 2732 Leapin' Lizards (拆点最大流)

    题意:有N*M的矩形,每个格点有一个柱子,每根柱子有高度c,允许蜥蜴经过这根柱子c次,开始有一些蜥蜴在某些柱子上,它们要跳出这个矩形,每步最大能跳d个单位,求最少有多少蜥蜴不能跳出这个矩形. 分析:转 ...

  4. HDU 2732 Leapin' Lizards(最大流)

    http://acm.hdu.edu.cn/showproblem.php?pid=2732 题意: 给出n行的网格,还有若干只蜥蜴,每只蜥蜴一开始就在一个格子之中,并且给出蜥蜴每次的最大跳跃长度d. ...

  5. HDU 2732 Leapin' Lizards

    网络最大流+拆点.输出有坑!!! #include<cstdio> #include<cstring> #include<string> #include<c ...

  6. hdu 2732 Leapin' Lizards(最大流)Mid-Central USA 2005

    废话: 这道题不难,稍微构造一下图就可以套最大流的模板了.但是我还是花了好久才解决.一方面是最近确实非常没状态(托词,其实就是最近特别颓废,整天玩游戏看小说,没法静下心来学习),另一方面是不够细心,输 ...

  7. hdu2732 Leapin' Lizards 最大流+拆点

    Your platoon of wandering lizards has entered a strange room in the labyrinth you are exploring. As ...

  8. HDU 2732 Leapin&#39; Lizards(拆点+最大流)

    HDU 2732 Leapin' Lizards 题目链接 题意:有一些蜥蜴在一个迷宫里面,有一个跳跃力表示能跳到多远的柱子,然后每根柱子最多被跳一定次数,求这些蜥蜴还有多少是不管怎样都逃不出来的. ...

  9. HDU-2732-leapin'Lizards(最大流, 拆点)

    链接: https://vjudge.net/problem/HDU-2732 题意: Your platoon of wandering lizards has entered a strange ...

随机推荐

  1. IDEA整合Mybatis+Struts2+Spring (二)--整合框架

    二.搭建目录结构 我这里列出的是搭建完了之后所有的目录和文件,诸位先把目录文件建起来,然后我在给出文件内容 这里的目录建好之后还需要设置一下,让idea识别目录作用,选择File-Project St ...

  2. 在生产环境下实现每天自动备份mysql数据库

    1.描述 我相信很多朋友在工作都都会有这种需求,老板或领导让你每天都要备份mysql数据库,你该如何实现呢,是每天到一定的时间在服务器上敲一遍mysql的备份命令,还是想写个脚本,定时定点的自动备份呢 ...

  3. Foxmail登录不了网易企业邮箱解决办法

    关于Foxmail登录不了网易企业邮箱问题 解决办法是:在设置账号的时候手动设置pop服务器和smtp服务器. 新建账号的图: 点击“手动设置”出现如下界面: 设置完成后问题解决.下面的两个是正确的, ...

  4. Python知识点入门笔记——基本运算和表达式

    变量:Python的变量不需要单独定义,直接在赋值的过程中完成定义. 当直接运行一个没有赋值过的变量时,会报错. 当不需要某个变量时,可以用del来删除 每个变量都占据着一定的内存空间,当变量被删除了 ...

  5. Python中字符串String的基本内置函数与过滤字符模块函数的基本用法

    Python中字符串String的基本内置函数与用法 首先我们要明白在python中当字符编码为:UTF-8时,中文在字符串中的占位为3个字节,其余字符为一个字节 下面就直接介绍几种python中字符 ...

  6. Django2.2使用mysql数据库pymysql版本不匹配问题的解决过程与总结

    前置条件 django版本:2.2.1 python版本:3.6.6 mysql版本:mysql-community8.0.15 问题 在搭建django项目,配置mysql数据库时遇到无法迁移数据库 ...

  7. while循环中continue和break的区别

    除了满足while条件外,还有两种方法可以终止循环,它们分别是break和continue.它们唯一的区别是break跳出整个循环,直接执行下面的代码了;而continue是终止当次循环,不执行下面的 ...

  8. Find a path HDU - 5492 (dp)

    Find a path Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  9. A1012 The Best Rank (25)(25 分)

    A1012 The Best Rank (25)(25 分) To evaluate the performance of our first year CS majored students, we ...

  10. HDU:2222-Keywords Search(AC自动机模板,匹配模拟)

    Keywords Search Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) P ...