NOI2009 植物大战僵尸
啊一道好题
感觉写得挺爽的啊这题
这种有一点懵逼然后学了一点东西之后很明朗的感觉真是好!
预处理参考 :http://www.cppblog.com/MatoNo1/archive/2014/11/01/142798.html?opt=admin
建图参考 :http://hihocoder.com/problemset/problem/1398?sid=1010444
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<string>
#include<algorithm>
#include<queue>
#include<vector>
#define N 80000
#define mod
#define inf 300000000
#define rg register
using namespace std;
typedef long long ll;
int n,m,tot=0,cnt=0,tmp=0,s,t;
int dis[N],hd[N],head[N],c[N],in[N],d[(N<<3)],w[N];
bool del[N];
struct hh{
int to,nxt,w;
}b1[N*100],b[N*100];
int p (int x,int y) { return (x-1)*m+y; }
void link(int x,int y,int w){
b1[tot].nxt=hd[x];
b1[tot].to=y;
b1[tot].w=w;
hd[x]=tot++;
}
void lnk(int x,int y,int w){
b[tot].nxt=head[x];
b[tot].to=y;
b[tot].w=w;
head[x]=tot++;
}
void dele(int x){
del[x]=1;
for (int i=hd[x];i!=-1;i=b1[i].nxt)
if (!del[b1[i].to]) dele(b1[i].to);
}
void top(){
int h=0,t=0;
for (int i=1;i<=cnt;++i){
if (!in[i]) d[++t]=i;
else del[i]=1;
}
while (h<=t){
int x=d[++h];
for (int i=hd[x];i!=-1;i=b1[i].nxt){
in[b1[i].to]--,del[b1[i].to]=0;
if (!in[b1[i].to]) d[++t]=b1[i].to;
}
}
for (int i=1;i<=cnt;++i) if (del[i]) dele(i);
}
bool bfs(){
queue <int> q;
memset(dis,-1,sizeof(dis));
q.push(s);dis[s]=0;
while (!q.empty()){
int h=q.front();
q.pop();
for (int i=head[h];i!=-1;i=b[i].nxt){
int v=b[i].to;
if (dis[v]!=-1||b[i].w<=0) continue;
dis[v]=dis[h]+1;
if (v==t) return 1;
q.push(v);
}
}
return dis[t]==-1?0:1;
}
int dfs(int u,int f){
if (u==t||!f) return f;
int res=f;
for (int &i=c[u];i!=-1;i=b[i].nxt){
int v=b[i].to;
if (dis[v]!=dis[u]+1||b[i].w<=0) continue;
int d=dfs(v,min(res,b[i].w));
b[i].w-=d,b[i^1].w+=d;
res-=d;
if (res<=0) break;
}
return f-res;
}
int dinic(){
int ans=0;
while (bfs()){
for (int i=s;i<=t;++i) c[i]=head[i];
ans+=dfs(s,inf);
}
return ans;
}
int main(){
freopen ("pvz.in","r",stdin);
freopen ("pvz.out","w",stdout);
memset(hd,-1,sizeof(hd));
memset(head,-1,sizeof(head));
scanf ("%d%d",&n,&m);
int x,y,z;
for (int i=1;i<=n;++i)
for (int j=1;j<=m;++j){
scanf ("%d%d",&w[p(i,j)],&z);
for (int k=1;k<=z;++k) scanf ("%d%d",&x,&y),link(p(i,j),p(x+1,y+1),0),in[p(x+1,y+1)]++;
}
for (int i=1;i<=n;++i)
for (int j=2;j<=m;++j) link(p(i,j),p(i,j-1),0),in[p(i,j-1)]++;
cnt=n*m;
top();
s=0,t=cnt+1,tmp=0;
tot=0;
for (int i=1;i<=cnt;++i){
if (del[i]) continue;
if (w[i]>0) tmp+=w[i],lnk(i,t,w[i]),lnk(t,i,0);
else lnk(s,i,-w[i]),lnk(i,s,0);
for (int j=hd[i];j!=-1;j=b1[j].nxt)
if (!del[b1[j].to]) lnk(i,b1[j].to,inf),lnk(b1[j].to,i,0);
}
tmp-=dinic();
printf ("%d\n",max(0,tmp));
return 0;
}
NOI2009 植物大战僵尸的更多相关文章
- 图论(网络流):COGS 410. [NOI2009] 植物大战僵尸
410. [NOI2009] 植物大战僵尸 ★★★ 输入文件:pvz.in 输出文件:pvz.out 简单对比时间限制:2 s 内存限制:512 MB [问题描述] Plants vs ...
- P2805 [NOI2009]植物大战僵尸
题目地址:P2805 [NOI2009]植物大战僵尸 最大权闭合子图 若有向图 \(G\) 的子图 \(V\) 满足: \(V\) 中顶点的所有出边均指向 \(V\) 内部的顶点,则称 \(V\) 是 ...
- COGS410. [NOI2009] 植物大战僵尸
410. [NOI2009] 植物大战僵尸 ★★★ 输入文件:pvz.in 输出文件:pvz.out 简单对比时间限制:2 s 内存限制:512 MB [问题描述] Plants vs ...
- BZOJ 1565: [NOI2009]植物大战僵尸
1565: [NOI2009]植物大战僵尸 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2317 Solved: 1071[Submit][Stat ...
- 【刷题】BZOJ 1565 [NOI2009]植物大战僵尸
Description Plants vs. Zombies(PVZ)是最近十分风靡的一款小游戏.Plants(植物)和Zombies(僵尸)是游戏的主角,其中Plants防守,而Zombies进攻. ...
- 【bzoj1565】[NOI2009]植物大战僵尸
1565: [NOI2009]植物大战僵尸 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 2164 Solved: 1001[Submit][Stat ...
- 【最大权闭合子图 tarjan】bzoj1565: [NOI2009]植物大战僵尸
dinic+tarjan板子练手题 Description Plants vs. Zombies(PVZ)是最近十分风靡的一款小游戏.Plants(植物)和Zombies(僵尸)是游戏的主角,其 中P ...
- BZOJ1565: [NOI2009]植物大战僵尸
Description Input Output 仅包含一个整数,表示可以获得的最大能源收入.注意,你也可以选择不进行任何攻击,这样能源收入为0. Sample Input 3 2 10 0 20 0 ...
- 【bzoj1565】 NOI2009—植物大战僵尸
http://www.lydsy.com/JudgeOnline/problem.php?id=1565 (题目链接) 题意 给出$n*m$的棋盘,僵尸攻击每个格子可以获得$v$的分数,每个格子又会保 ...
- luogu2805 [NOI2009]植物大战僵尸
想象一下,要搞掉一个植物,必须先搞掉另一些植物--我们可以发现这是一个最大权闭合子图的问题. 最大权闭合子图的话,太空飞行计划问题是一个入门题,可以一看. 然而我们手玩一下样例就会惊恐地发现,保护关系 ...
随机推荐
- 【ElementUI】日期选择器时间选择范围限制
ElementUI是饿了么推出的一套基于vue2.x的一个ui框架.官方文档也很详细,这里做一个element-ui日期插件的补充. 官方文档中使用picker-options属性来限制可选择的日期, ...
- python基础0
1.运行:D:\tools\python\python-2.7.10.amd64=>安装到c:\python 2.环境变量:path:c:\Python27 3.cmd:python回车 //s ...
- 如何清除PHP中不需要的Layout模板
最简单的办法就是在需要清除的静态页的最前端加上 {__NOLAYOUT__} 就可以清除所有的layout效果, 继而设置自己的css.js效果.
- struct 类型指针技巧
此类型对于两种结构的查找和删除都十分方便,实际项目中也常常用到.
- Springboot Mybatis Redis 实现二级缓存
前言 什么是mybatis二级缓存? 二级缓存是多个sqlsession共享的,其作用域是mapper的同一个namespace. 即,在不同的sqlsession中,相同的namespace下,相同 ...
- MYSQL 主从复制---简单易学
本帖最后由 传说中的草包 于 2017-4-12 09:12 编辑为什么要用mysql主从复制? 这个问题不需要回答吧,,,,,想想,一个人干活快呢,还是一万个能性格功力一样的人干活快呢. 不用解释大 ...
- Shell中处理方法返回值问题
同步发表:http://blog.hacktons.cn/2017/12/13/shell-func-return/ 背景 通过shell编程,写一些工具批处理的时候,经常需要自定义函数.更复杂点的情 ...
- NOI导刊2010提高装备运输
www.luogu.org/problem/show?pid=1794 挺裸的一题背包,算很基础. 可以运用的技巧是三维->二维(节省空间还能少敲一点代码 #include<iostrea ...
- python中namedtuple介绍
namedtuple:namedtuple类位于collections模块,有了namedtuple后通过属性访问数据能够让我们的代码更加的直观更好维护.namedtuple能够用来创建类似于元祖的数 ...
- 剑指Offer_6_从尾到头打印链表
题目描述 输入应该链表的头节点 , 从尾到头反过来打印出每个节点的值.链表定义如下 : typedef struct ListNode { int m_nKey ; ListNode * ...