Description

传送门

Solution

em本题知识点是用网络流求最大点权闭合子图。

闭合图定义:图中任何一个点u,若有边u->v,则v必定也在图中。

建图:运用最小割思想,将S向点权为正的点连边,流量为点权;点权为负的点向T连边,流量为点权的绝对值;原图之间的边流量为inf(表明不能割)。答案就是所有正点权之和-该网络流图的最小割(证明还未补qaq)

是不是觉得这个闭合图定义特别的眼熟?似乎可以套在这道题上。(题意:假如你要吃掉某个植物,需要先吃掉这个植物对应的集合,求最大的能源收入。)假如植物v保护u【ps:在u后面的植物也算作保护u】,则连边u->v。

当然需要注意,有些植物是RMB玩家哈哈(就是,它们的保护关系可以构成一个环),则这些植物和它们所保护的植物都是不能被吃掉的。RMB玩家可以用拓扑排序完美KO(当然,要把边反向建。原因。。因为我们还要找出所有环上植物们"所保护的植物")

Code

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<queue>
using namespace std;
const int inf=1e9; int h[],tot=;
struct pas{int x,y,nxt,w,op,cost;}g[];
int dep[],S,T;
queue<int>q;
struct DINIC{
bool bfs()
{
int x;
memset(dep,,sizeof(dep));dep[S]=;
while (!q.empty()) q.pop();
q.push(S);
while (!q.empty())
{
x=q.front();q.pop();
for (int i=h[x];i;i=g[i].nxt)
if (!dep[g[i].y]&&g[i].w)
{
dep[g[i].y]=dep[x]+;
q.push(g[i].y);
if (g[i].y==T) return ;
}
}
return ;
}
int dfs(int x,int flow)
{
if (x==T||(!flow))return flow;
int temp=,js;
for (int i=h[x];i;i=g[i].nxt)
if (dep[g[i].y]==dep[x]+&&g[i].w)
{
js=dfs(g[i].y,min(flow,g[i].w));
if (js)
{
g[i].w-=js;
g[g[i].op].w+=js;
temp+=js;
flow-=js;
if (!flow) return temp;
}
}
if (!temp) dep[x]=;
return temp;
}
int dinic()
{
int ans=;
while (bfs())
ans+=dfs(S,inf);
return ans;
}
}D; void add(int x,int y,int w)
{
g[++tot].x=x;g[tot].y=y;g[tot].w=w;g[tot].nxt=h[x];g[tot].op=tot+;h[x]=tot;
g[++tot].x=y;g[tot].y=x;g[tot].w=;g[tot].nxt=h[y];g[tot].op=tot-;h[y]=tot;
} int n,m,cnt,r,c,TOT,_v[];
int id(int x,int y) {return (x-)*m+y;}
bool not_cir[];int d[]; pas e[];
int e_tot=,e_h[];
void adde(int x,int y)
{
e[++e_tot]=pas{x,y,e_h[x],,,};e_h[x]=e_tot;
d[y]++;
}
void check()
{
while (!q.empty()) q.pop();
for (int i=;i<=n*m;i++) if (!d[i]) q.push(i),not_cir[i]=;
while (!q.empty())
{
int x=q.front();q.pop();
for (int i=e_h[x];i;i=e[i].nxt)
{
d[e[i].y]--;
if (!d[e[i].y]) not_cir[e[i].y]=,q.push(e[i].y);
}
}
}
int main()
{
scanf("%d%d",&n,&m);
S=;T=n*m+;
for (int i=;i<=n;i++) for (int j=;j<=m;j++)
{
scanf("%d",&_v[id(i,j)]);
scanf("%d",&cnt);
for (int k=;k<=cnt;k++)
{
scanf("%d%d",&r,&c);adde(id(i,j),id(r+,c+));
}
if (j!=m) adde(id(i,j+),id(i,j));
}
check();
for (int i=;i<=e_tot;i++) if (not_cir[e[i].x]&&not_cir[e[i].y])add(e[i].y,e[i].x,inf);
for (int i=;i<=n*m;i++) if (not_cir[i]) {if (_v[i]>) add(S,i,_v[i]),TOT+=_v[i];else add(i,T,-_v[i]);}
int ans=;
while (D.bfs())
ans+=D.dfs(S,inf);
printf("%d",TOT-ans);
}

[BZOJ1565][NOI2009]植物大战僵尸-[网络流-最小割+最大点权闭合子图+拓扑排序]的更多相关文章

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

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

  2. bzoj1565: [NOI2009]植物大战僵尸 最大权闭合子图,tarjan

    bzoj1565: [NOI2009]植物大战僵尸 链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1565 思路 很容易的想到最大权闭合子图 ...

  3. bzoj1565【NOI2009】植物大战僵尸(最小割)

    题目描述 Plants vs. Zombies(PVZ)是最近十分风靡的一款小游戏.Plants(植物)和Zombies(僵尸)是游戏的主角,其中Plants防守,而Zombies进攻.该款游戏包含多 ...

  4. [bzoj1565][NOI2009]植物大战僵尸_网络流_拓扑排序

    植物大战僵尸 bzoj1565 题目大意:给你一张网格图,上面种着一些植物.你从网格的最右侧开始进攻.每个植物可以对僵尸提供能量或者消耗僵尸的能量.每个植物可以保护一个特定网格内的植物,如果一个植物被 ...

  5. LibreOJ #6007. 「网络流 24 题」方格取数 最小割 最大点权独立集 最大流

    #6007. 「网络流 24 题」方格取数 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据   题目描述 ...

  6. 洛谷$P2805\ [NOI2009]$植物大战僵尸 网络流

    正解:网络流 解题报告: 传送门$QwQ$ 题面好长昂,,,我大概概括下$QwQ$?有个$n\cdot m$的网格,每个格子有一株植物,击溃一株植物$(x,y)$需要付出$S_{(x,y)}$的代价( ...

  7. BZOJ1565[NOI2009]植物大战僵尸——最大权闭合子图+拓扑排序

    题目描述 Plants vs. Zombies(PVZ)是最近十分风靡的一款小游戏.Plants(植物)和Zombies(僵尸)是游戏的主角,其中Plants防守,而Zombies进攻.该款游戏包含多 ...

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

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

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

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

随机推荐

  1. 深入理解 iOS Rendering Process

    本文将从 OpenGL 的角度结合 Apple 官方给出的部分资料,介绍 iOS Rendering Process 的概念及其整个底层渲染管道的各个流程. 相信在理解了 iOS Rendering ...

  2. 「NOIP2018 保卫王国」

    题目 强制选点我们可以把那个点权搞成\(-inf\),强制不选我们搞成\(inf\),之后就真的成为动态\(dp\)的板子题了 由于不想像板子那样再写一个最大独立集的方程,之后利用最小点覆盖=总点权- ...

  3. 基于Azure Blob冷存储的数据压缩算法测试对比分析

    背景说明: 近期公司的数据增量迅速增长,存储的成本太高,需要采用生命周期进行管理,热存储中的数据或者被删除,或者备份至冷存储.但是冷备时是否要压缩,需要进行验证.Azure本身没有提供压缩的接口,只能 ...

  4. QTP基本方法

    1.for循环: m代表间隔循环长度: 如果m>0,则j要大于i: 如果m<0,则i要大于j: for i to j [step m] 语句块 [exit for]//强制退出循环 nex ...

  5. Linux开启路由的方法

    Linux开启路由的命令很简单,只需要一条命令即可: [root@localhost ~]# echo 1 > /proc/sys/net/ipv4/ip_forward 这个只是临时修改,如果 ...

  6. e2fsprogs

    开源文件系统ext2/ext3/ext4管理工具e2progs包含的工具组件: 1.debugfs: ext2/ext3/ext4文件系统调试工具.debugfs是一个交互式的文件系统调试工具,可以用 ...

  7. JAVA并发(一)

    java并发的一系列框架和技术主要是由java.util.concurrent 包所提供.包下的所有类可以分为如下几大类: locks部分:显式锁(互斥锁和速写锁)相关: atomic部分:原子变量类 ...

  8. spring boot 配置Rabbit

    单独安装Rabbit服务并设置启动,可以通过浏览器访问,一般访问地址是http://localhost:15672/ ,用户名密码看配置文件的用户名密码 1 实例化配置类注解 import org.s ...

  9. java ssm 后台框架平台 项目源码 websocket 即时通讯 IM quartz springmvc

    官网 http://www.fhadmin.org/D 集成安全权限框架shiro  Shiro 是一个用 Java 语言实现的框架,通过一个简单易用的 API 提供身份验证和授权,更安全,更可靠E ...

  10. 编程开发之--Oracle数据库--存储过程在out参数中使用光标(3)

    在本系列学习随笔中的第2节我们留下了2个问题,我们现在讨论在out参数中使用光标. 1.要在out参数中使用光标,我们需要申明一个包的结构,包的结构分为包头和包体,包头只负责申明,包体只负责实现.包头 ...