先拓扑排序搞出合法的, 然后就是最大权闭合图模型了....

---------------------------------------------------------------------

#include<cstdio>
#include<cstring>
#include<algorithm>
 
using namespace std;
 
#define Id(x, y) ((x) * c + (y))
 
const int maxv = 700;
const int INF = 10000000;
 
int r, c;
int deg[maxv], w[maxv], q[maxv], Id[maxv];
 
struct edge {
int t;
edge* nxt;
} E[maxv * maxv], *pt = E, *Head[maxv];
 
inline void AddEdge(int u, int v) {
deg[pt->t = v]++, pt->nxt = Head[u], Head[u] = pt++;
}
 
namespace G {
struct edge {
int t, c;
edge *nxt, *rev;
} E[maxv * maxv], *e = E, *Head[maxv], *p[maxv], *cur[maxv];
int V, h[maxv], cnt[maxv];
inline void Add(int u, int v, int c) {
e->t = v, e->c = c, e->nxt = Head[u], Head[u] = e++;
}
inline void AddEdge(int u, int v, int c) {
Add(u, v, c), Add(v, u, 0);
Head[u]->rev = Head[v];
Head[v]->rev = Head[u];
}
void Work() {
int S = V++, T = V++, ans = 0;
for(int i = r * c; i--; ) if(~Id[i]) {
if(w[i] > 0) {
ans += w[i], AddEdge(S, Id[i], w[i]);
} else
AddEdge(Id[i], T, -w[i]);
}
for(int i = 0; i < V; i++)
cnt[i] = h[i] = 0, cur[i] = Head[i];
cnt[0] = V;
for(int x = S, A = INF; h[S] < V; ) {
for(e = cur[x]; e; e = e->nxt)
if(e->c && h[e->t] + 1 == h[x]) break;
if(e) {
p[e->t] = cur[x] = e;
A = min(A, e->c);
if((x = e->t) == T) {
for(; x != S; x = p[x]->rev->t)
p[x]->c -= A, p[x]->rev->c += A;
ans -= A, A = INF;
}
} else {
if(!--cnt[h[x]]) break;
h[x] = V;
for(e = Head[x]; e; e = e->nxt) if(h[e->t] + 1 < h[x] && e->c)
h[x] = h[e->t] + 1, cur[x] = e;
cnt[h[x]]++;
if(x != S) x = p[x]->rev->t;
}
}
printf("%d\n", ans);
}
}
 
void Init() {
int n;
scanf("%d%d", &r, &c);
memset(deg, 0, sizeof deg);
memset(Id, -1, sizeof Id);
for(int i = 0; i < r; i++)
for(int j = 0; j < c; j++) {
scanf("%d%d", w + Id(i, j), &n);
while(n--) {
int x, y; scanf("%d%d", &x, &y);
AddEdge(Id(i, j), Id(x, y));
}
if(j) AddEdge(Id(i, j), Id(i, j - 1));
}
}
 
void BFS() {
int h = 0, t = 0, x, &V = G::V = 0;
for(int i = r * c; i--; )
if(!deg[i]) q[t++] = i;
while(h < t) {
Id[x = q[h++]] = V++;
for(edge* e = Head[x]; e; e = e->nxt)
if(!--deg[e->t]) q[t++] = e->t;
}
}
 
void Work() {
for(int i = r * c; i--; ) if(~Id[i])
for(edge* e = Head[i]; e; e = e->nxt)
if(~Id[e->t]) G::AddEdge(Id[e->t], Id[i], INF);
G::Work();
}
 
int main() {
Init();
BFS();
Work();
return 0;
}

---------------------------------------------------------------------

1565: [NOI2009]植物大战僵尸

Time Limit: 10 Sec  Memory Limit: 64 MB
Submit: 1807  Solved: 835
[Submit][Status][Discuss]

Description

Input

Output

仅包含一个整数,表示可以获得的最大能源收入。注意,你也可以选择不进行任何攻击,这样能源收入为0。

Sample Input

3 2
10 0
20 0
-10 0
-5 1 0 0
100 1 2 1
100 0

Sample Output

25

HINT

在样例中, 植物P1,1可以攻击位置(0,0), P2, 0可以攻击位置(2,1)。 
一个方案为,首先进攻P1,1, P0,1,此时可以攻击P0,0 。共得到能源收益为(-5)+20+10 = 25。注意, 位置(2,1)被植物P2,0保护,所以无法攻击第2行中的任何植物。 
【大致数据规模】
约20%的数据满足1 ≤ N, M ≤ 5;
约40%的数据满足1 ≤ N, M ≤ 10;
约100%的数据满足1 ≤ N ≤ 20,1 ≤ M ≤ 30,-10000 ≤ Score ≤ 10000 。

Source

BZOJ 1565: [NOI2009]植物大战僵尸( 最小割 )的更多相关文章

  1. bzoj 1565 [NOI2009]植物大战僵尸 解题报告

    1565: [NOI2009]植物大战僵尸 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 2161  Solved: 1000[Submit][Stat ...

  2. Bzoj 1565: [NOI2009]植物大战僵尸 最大权闭合图,拓扑排序

    题目: http://cojs.tk/cogs/problem/problem.php?pid=410 410. [NOI2009] 植物大战僵尸 ★★★   输入文件:pvz.in   输出文件:p ...

  3. BZOJ 1565 NOI2009 植物大战僵尸 topo+最小割(最大权闭合子图)

    题目链接:https://www.luogu.org/problemnew/show/P2805(bzoj那个实在是有点小小的辣眼睛...我就把洛谷的丢出来吧...) 题意概述:给出一张有向图,这张有 ...

  4. BZOJ 1565 [NOI2009]植物大战僵尸 | 网络流

    传送门 BZOJ 1565 题解 这道题也是个经典的最大权闭合子图-- 复习一下最大权闭合子图是什么? 就是一个DAG上,每个点有个或正或负的点权,有的点依赖于另外一些点(如果选这个点,则被依赖点必选 ...

  5. P2805 [NOI2009]植物大战僵尸(最小割+拓扑排序)

    题意: n*m的矩阵,每个位置都有一个植物.每个植物都有一个价值(可以为负),以及一些它可以攻击的位置.从每行的最右面开始放置僵尸,僵尸从右往左行动,当僵尸在植物攻击范围内时会立刻死亡.僵尸每到一个位 ...

  6. bzoj 1565 [NOI2009]植物大战僵尸【tarjan+最大权闭合子图】

    一上来以为是裸的最大权闭合子图,上来就dinic -然后没过样例.不得不说样例还是非常良心的给了一个强连通分量,要不然就WA的生活不能自理了 然后注意到有一种特殊情况:每个植物向他保护的植物连边(包括 ...

  7. BZOJ 1565: [NOI2009]植物大战僵尸(网络流+缩点)

    传送门 解题思路 最大权闭合子图.但是要注意一些细节,假如有一堆植物形成一个环,那么这些植物都是无敌的,并且他们保护的植物是无敌的,他们保护的保护的植物是无敌 的.所以要缩点,然后拓扑排序一次判无敌, ...

  8. 1565: [NOI2009]植物大战僵尸 - BZOJ

    Description Input Output仅包含一个整数,表示可以获得的最大能源收入.注意,你也可以选择不进行任何攻击,这样能源收入为0.Sample Input3 210 020 0-10 0 ...

  9. BZOJ 1565: [NOI2009]植物大战僵尸

    1565: [NOI2009]植物大战僵尸 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 2317  Solved: 1071[Submit][Stat ...

随机推荐

  1. [ACM] hdu 2191 珍惜如今,感恩生活 (多重背包)

    Problem Description 急!灾区的食物依旧短缺! 为了拯救灾区同胞的生命,心系灾区同胞的你准备自己採购一些粮食支援灾区,如今如果你一共同拥有资金n元,而市场有m种大米,每种大米都是袋装 ...

  2. Girl_iOS100天学iOS的第一天(规划)

    不好的开端. 只是还好,总算是開始. 今天一直在做项目中的某个模块,发现自己尽管工作了一段时间,但编码速度还是够慢的 >.< 探究其为什么慢的原因,还是由于自己对某些控件等基础的不熟悉,如 ...

  3. jQuery+PHP实现的砸金蛋中奖程序

    准备 我们需要准备道具(素材),即相关图片,包括金蛋图片.蛋砸碎后的图片.砸碎后的碎花图片.以及锤子图片. HTML 我们页面上要展现的是一个砸金蛋的台子,台上放了编号为1,2,3的三个金蛋,以及一把 ...

  4. wcf系列学习5天速成——第四天 wcf之分布式架构

    今天是wcf系列的第四天,也该出手压轴戏了.嗯,现在的大型架构,都是神马的, nginx鸡群,iis鸡群,wcf鸡群,DB鸡群,由一个人作战变成了群殴....... 今天我就分享下wcf鸡群,高性能架 ...

  5. 关于css3中before与after用单冒号还是双冒号的疑虑

    在 CSS3 中为了区别伪元素和伪类为伪元素使用了双冒号,因此如果使用了 display 或者 width 等属性时使得显示脱离了原本元素后,建议按照标准双写.

  6. PO状态为“处理中”的处理方法

    EBS中经常会出现PO提交审批后状态为“处理中”的情况,此时PO创建人无法打开,审批人也无法打开,工作流等查看也无异常,可以使用一下SQL处理再进行审批: --set serveroutput on ...

  7. 一致性哈希(Consistent Hashing)

    前言:对于一致性哈希已经不是罕见概念,在此只是对原有理论概念的一个整理和用自己的理解讲述,希望对新手有些许帮助,利人利己足矣. 1.概念 一致哈希是一种特殊的哈希算法.在使用一致哈希算法后,哈希表槽位 ...

  8. [C++基础]在构造函数内部调用构造函数

    看下面的面试题: #include <iostream> using namespace std; struct CLS { int m_i; CLS( int i ) : m_i(i){ ...

  9. placeholder颜色

    ::-moz-placeholder{color:#b9bfc1;} // Firefox::-webkit-input-placeholder{color:#b9bfc1;} // Chrome, ...

  10. flush privileges是什么意思?

    flush privileges 命令本质上的作用是将当前user和privilige表中的用户信息/权限设置从mysql库(MySQL数据库的内置库)中提取到内存里.MySQL用户数据和权限有修改后 ...