贪心+网络流。对于每个结点,构建入点和出点。
对于每一个lizard>0,构建边s->in position of lizard, 容量为1.
对于pillar>0, 构建边in position of pillar -> out position of pillar, 容量为number of pillar.
若沿四个方向移动距离d可以超过边界,则构建边out position of pillar -> t, 容量为INF;
否则, 对于曼哈顿距离l(l>0 and l<=d)的点p构建边out position of pillar -> in position p, 容量为INF。(此时,不用考虑p是否含有pillar,无所谓)
Dinic可解网络流。一定要注意输出was/were,单复数和0等。

 /* 2732 */
#include <iostream>
#include <string>
#include <map>
#include <queue>
#include <set>
#include <stack>
#include <vector>
#include <deque>
#include <algorithm>
#include <cstdio>
#include <cmath>
#include <ctime>
#include <cstring>
#include <climits>
#include <cctype>
#include <cassert>
#include <functional>
#include <iterator>
#include <iomanip>
using namespace std;
//#pragma comment(linker,"/STACK:102400000,1024000") #define sti set<int>
#define stpii set<pair<int, int> >
#define mpii map<int,int>
#define vi vector<int>
#define pii pair<int,int>
#define vpii vector<pair<int,int> >
#define rep(i, a, n) for (int i=a;i<n;++i)
#define per(i, a, n) for (int i=n-1;i>=a;--i)
#define clr clear
#define pb push_back
#define mp make_pair
#define fir first
#define sec second
#define all(x) (x).begin(),(x).end()
#define SZ(x) ((int)(x).size())
#define lson l, mid, rt<<1
#define rson mid+1, r, rt<<1|1 const int INF = 0x1f1f1f1f;
const int maxn = ;
const int maxv = maxn*maxn*;
const int maxe = maxv*maxn*;
int V[maxe], F[maxe], nxt[maxe];
int head[maxv], dis[maxv];
char Ps[maxn][maxn], Ls[maxn][maxn];
int dir[][] = {
-, , , , , -, ,
};
int n, m; void addEdge(int u, int v, int c) {
V[m] = v;
F[m] = c;
nxt[m] = head[u];
head[u] = m++; V[m] = u;
F[m] = ;
nxt[m] = head[v];
head[v] = m++;
} bool bfs(int s, int t) {
queue<int> Q;
int u, v, k; memset(dis, , sizeof(dis));
Q.push(s);
dis[s] = ; while (!Q.empty()) {
u = Q.front();
Q.pop();
for (k=head[u]; k!=-; k=nxt[k]) {
v = V[k];
if (!dis[v] && F[k]) {
dis[v] = dis[u] + ;
Q.push(v);
}
}
} return dis[t]==;
} int dfs(int u, int t, int val) {
if (u==t || val==)
return val; int ret = ;
int tmp, v, k; for (k=head[u]; k!=-; k=nxt[k]) {
v = V[k];
if (dis[v]==dis[u]+ && F[k] && (tmp=dfs(v, t, min(val, F[k])))>) {
F[k] -= tmp;
F[k^] += tmp;
ret += tmp;
val -= tmp;
if (val == )
break;
}
} return ret;
} int Dinic(int s, int t) {
int ret = , tmp; while () {
if (bfs(s, t))
break; tmp = dfs(s, t, INF);
ret += tmp;
} return ret;
} int main() {
ios::sync_with_stdio(false);
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
freopen("data.out", "w", stdout);
#endif int case_n;
int s, t, n_, m_, d, tmp;
int x, y;
int k, id, id_;
int ans, tot;
bool flag; scanf("%d", &case_n);
rep(tt, , case_n+) {
scanf("%d %d", &n_, &d); rep(i, , n_+)
scanf("%s", Ps[i]+);
rep(i, , n_+)
scanf("%s", Ls[i]+); m_ = strlen(Ps[]+);
tot = ;
s = m = ;
k = n_ * m_;
t = k*+;
memset(head, -, sizeof(head)); rep(i, , n_+) {
rep(j, , m_+) {
id = (i-) * m_ + j;
if (Ls[i][j] == 'L') {
addEdge(s, id, );
++tot;
}
if (Ps[i][j] > '') {
addEdge(id, id+k, Ps[i][j]-'');
flag = true;
id += k;
rep(kk, , ) {
x = i + dir[kk][] * d;
y = j + dir[kk][] * d;
if (x<= || x>n_ || y<= || y>m_) {
addEdge(id, t, INF);
flag = false;
break;
}
}
if (flag) {
id_ = ;
rep(ii, , n_+) {
rep(jj, , m_+) {
++id_;
tmp = abs(ii-i) + abs(jj-j);
if (tmp> && tmp<=d)
addEdge(id, id_, Ps[i][j]-'');
}
}
}
}
}
} ans = tot - Dinic(s, t);
printf("Case #%d: ", tt);
if (ans == ) {
printf("no lizard was left behind.\n");
} else if (ans == ) {
printf("1 lizard was left behind.\n");
} else {
printf("%d lizards were left behind.\n", ans);
}
} #ifndef ONLINE_JUDGE
printf("time = %d.\n", (int)clock());
#endif return ;
}

【HDOJ】2732 Leapin' Lizards的更多相关文章

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

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

  2. 【HDOJ】4729 An Easy Problem for Elfness

    其实是求树上的路径间的数据第K大的题目.果断主席树 + LCA.初始流量是这条路径上的最小值.若a<=b,显然直接为s->t建立pipe可以使流量最优:否则,对[0, 10**4]二分得到 ...

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

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

  4. 【HDOJ】【3506】Monkey Party

    DP/四边形不等式 裸题环形石子合并…… 拆环为链即可 //HDOJ 3506 #include<cmath> #include<vector> #include<cst ...

  5. 【HDOJ】【3516】Tree Construction

    DP/四边形不等式 这题跟石子合并有点像…… dp[i][j]为将第 i 个点开始的 j 个点合并的最小代价. 易知有 dp[i][j]=min{dp[i][j] , dp[i][k-i+1]+dp[ ...

  6. 【HDOJ】【3480】Division

    DP/四边形不等式 要求将一个可重集S分成M个子集,求子集的极差的平方和最小是多少…… 首先我们先将这N个数排序,容易想到每个自己都对应着这个有序数组中的一段……而不会是互相穿插着= =因为交换一下明 ...

  7. 【HDOJ】【2829】Lawrence

    DP/四边形不等式 做过POJ 1739 邮局那道题后就很容易写出动规方程: dp[i][j]=min{dp[i-1][k]+w[k+1][j]}(表示前 j 个点分成 i 块的最小代价) $w(l, ...

  8. 【HDOJ】【3415】Max Sum of Max-K-sub-sequence

    DP/单调队列优化 呃……环形链求最大k子段和. 首先拆环为链求前缀和…… 然后单调队列吧<_<,裸题没啥好说的…… WA:为毛手写队列就会挂,必须用STL的deque?(写挂自己弱……s ...

  9. 【HDOJ】【3530】Subsequence

    DP/单调队列优化 题解:http://www.cnblogs.com/yymore/archive/2011/06/22/2087553.html 引用: 首先我们要明确几件事情 1.假设我们现在知 ...

随机推荐

  1. Redis Cache 简介

    Microsoft Azure Redis Cache 是基于流行的开源Redis Cache 1.Microsoft Azure Redis Cache 可分为以下几个级别: Basic – 单节点 ...

  2. sql 常用操作脚本代码

    ,--运行fy_mh库[use] use fy_mh ,--查询 mh_dblj表 select * from mh_dblj ,--更新 某个字段(把表的某个字段下的所有的数据清空)[update ...

  3. windows下能读写linux分区的软件 转

    1. ext2ifs 这个工具与explore2fs都是John Newbigin使用Delphi写的,explore2fs Copyright (C) 2000,Ext2IFS v0.3 Copyr ...

  4. 几种JavaScript富应用MVC MVVM框架

    Ember.js.Backbone.js.Knockout.js.Spine.js.Batman.js , Angular.js 前端中的MVVM设计模式让UI与数据模型可以很轻松的相互更新,这意味着 ...

  5. Nagios-配置版

    1  概念(简介) Nagios是插件式的结构,它本身没有任何监控功能,所有的监控都是通过插件进行的,因此其是高度模块化和富于弹性的.Nagios监控的对象可分为两类:主机和服务.主机通常指的是物理主 ...

  6. ios Object Encoding and Decoding with NSSecureCoding Protocol

    Object Encoding and Decoding with NSSecureCoding Protocol February 27, 2014 MISC NSCoding is a fanta ...

  7. Jstl标签库/Filter过滤器

    JSTLJSP Standard Tag Library JSP标准标签库 是Sun公司定义的一套标准,由Apache组织基于这套标准开发的一套标准库之后又转给Sun公司被称为JSTL,成为了java ...

  8. 安装aptana插件报Error opening the editor. java.lang.NullPointerException

    Aptana的官方网站下载eclipse的插件:  http://update.aptana.com/update/studio/3.2/ ,可以在线安装也可以下载插件后再安装,我是以在线的形式安装的 ...

  9. jQuery 快速入门教程

    内容目录 jQuery 入门 什么是jQuery 如何使用jQuery jQuery的运行原理 如何选择jQuery版本 ready() 准备就绪时执行代码 jQuery 核心:选取元素 使用jQue ...

  10. PL/SQL学习(一)

    原文参考:http://plsql-tutorial.com/ 组成: 声明部分(可选) 执行部分(必选) 异常处理(可选)       声明:         DECLARE       执行:   ...