给定一个\(N \times M\)方格矩阵,每个格子可在\(0,1,2\)中取值。要求在方格的边上进行划分,使得任意联通块内不同时包含\(1\)和\(2\)的格子。


若对方格矩阵的形式感到困惑,我们可以先考虑图上的形式。

假设图中有节点\(W_1\),\(Q_1\),\(S_1\),\(S_2\),且\(W_1\)与其它三者间各有一边,此外\(Q_1\)和\(S_1\)间还有一边。\(W_1\)是1值节点,\(S_1,S_2\)是2值节点。现在考虑进行划分。

我们发现在原问题中,\(0\)值点无论和哪个点划在一个连通块内都是合法的。换言之,\(0\)值节点在这里只起到传导连通的作用。亦即任意两个连通节点间可以有任意个\(0\)值节点。

根据这一性质,我们对图进行分层。建立网络,将\(W_i\)作为第一层(靠近源点),\(S_i\)作为最后一层(靠近汇点),\(Q_i\)放中间。将原图中的连接关系单向地对应到网络中:

  • 由\(W_i\)向任意点的连接均转化为一条容量为\(1\)的弧
  • 由\(S_i\)向任意点的连接均被忽略
  • 由\(Q_i\)向非\(W_i\)点的连接均转化为一条容量为\(1\)的弧

容易发现,由于原图是无向图,我们在建立流网络时对其定向,从而避免对一个划分边的重复计算。而定向的依据则是依据\(W_i > Q_i > S_i\)的优先级顺序进行的。

这样建图后,求出的最大流就是流网络的最小割,也就是答案。


分析完图上的情况后,这里的情形就显得简单了。

我们考虑对任意格子\((i,j)\),其四周的格子即是上文中与之直接相连的节点。我们将图中的关系放到方格矩阵中处理就可以了。


#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<vector>
#include<queue>
#define G g
using namespace std;
struct Item{int p,v,c;};
Item item(int _p,int _v,int _c){Item it;it.p=_p;it.v=_v;it.c=_c;return it;}
vector <Item> g[100005];
int n,m,t1,t2,t3,dis[100005],d[100005],vis[100005],s,t,t4,costs=0,tans,ans,inc[100005],cnt=0,k,inp[100005][4],edg[100005];
vector <int> oppo[100005];
int dinic_spfa(){
memset(dis,0xff,sizeof dis);
memset(d,0x3f,sizeof d);
memset(vis,0x00,sizeof vis);
memset(inc,0x00,sizeof inc);
queue <int> q;
q.push(s); dis[s]=0; d[s]=0;
while(!q.empty()){
int p=q.front(); q.pop(); vis[p]=0; inc[p]++;
for(int i=0;i<g[p].size();i++){
if(d[g[p][i].p]>d[p]+g[p][i].v&&g[p][i].c>0){
dis[g[p][i].p]=p; edg[g[p][i].p]=i;
d[g[p][i].p]=d[p]+g[p][i].v;
if(vis[g[p][i].p]==0) vis[g[p][i].p]=1, q.push(g[p][i].p);}}}
return dis[t]>0;}
int dinic_dfs(){
int p=t,a=0x7fffffff;
while(p-s) a=min(a,g[dis[p]][edg[p]].c),p=dis[p];
int lc=costs;
p=t;
while(p-s){
int tc,i=edg[p];
G[dis[p]][i].c-=a,
G[p][oppo[dis[p]][i]].c+=a,
costs+=a*G[dis[p]][i].v;
p=dis[p];}
return a;}
int dinic_main(int src,int dest){
s=src; t=dest;
while(dinic_spfa()) ans+=dinic_dfs();
return ans;}
void build(int w,int x,int y,int z){
oppo[x].push_back(g[w].size());
g[w].push_back(item(x,z,y));
oppo[w].push_back(g[x].size());
g[x].push_back(item(w,-z,0));}
int main(){
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=m;i++) scanf("%d%d%d%d",&inp[i][0],&inp[i][1],&inp[i][2],&inp[i][3]),
build(inp[i][0],inp[i][1],inp[i][2],0);
dinic_main(1,n);
printf("%d ",ans);
for(int i=1;i<=m;i++)
build(inp[i][0],inp[i][1],0x7fffffff,inp[i][3]);
build(0,1,k,0);
dinic_main(0,n);
printf("%d\n",costs);
}

[ZJOI2009] 狼与羊的故事 - 最小割的更多相关文章

  1. BZOJ 1412: [ZJOI2009]狼和羊的故事( 最小割 )

    显然是最小割...把狼的领地连S, 羊的领地连T, 然后中间再连边, 跑最大流就OK了 -------------------------------------------------------- ...

  2. 【BZOJ1412】[ZJOI2009]狼和羊的故事 最小割

    [BZOJ1412][ZJOI2009]狼和羊的故事 Description “狼爱上羊啊爱的疯狂,谁让他们真爱了一场:狼爱上羊啊并不荒唐,他们说有爱就有方向......” Orez听到这首歌,心想: ...

  3. P2598 [ZJOI2009]狼和羊的故事(最小割)

    P2598 [ZJOI2009]狼和羊的故事 说真的,要多练练网络流的题了,这么简单的网络流就看不出来... 题目要求我们要求将狼和羊分开,也就是最小割,(等等什么逻辑...头大....) 我们这样想 ...

  4. BZOJ1412[ZJOI2009]狼和羊的故事——最小割

    题目描述 “狼爱上羊啊爱的疯狂,谁让他们真爱了一场:狼爱上羊啊并不荒唐,他们说有爱就有方向......” Orez听到这首歌,心想:狼和羊如此和谐,为什么不尝试羊狼合养呢?说干就干! Orez的羊狼圈 ...

  5. LG2598/BZOJ1412 「ZJOI2009」狼和羊的故事 最小割

    问题描述 LG2598 BZOJ1412 题解 看到要把狼和羊两个物种分开 自然想到最小割. 发现\((x,y)\)可以向上下左右走以获得贡献,所以建边:\((x,y),(x-1,y)\),\((x, ...

  6. BZOJ1412 ZJOI2009 狼和羊的故事 【网络流-最小割】

    BZOJ1412 ZJOI2009 狼和羊的故事 Description “狼爱上羊啊爱的疯狂,谁让他们真爱了一场:狼爱上羊啊并不荒唐,他们说有爱就有方向......” Orez听到这首歌,心想:狼和 ...

  7. BZOJ1412 [ZJOI2009]狼和羊的故事 【最小割】

    1412: [ZJOI2009]狼和羊的故事 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 3454  Solved: 1733 [Submit][ ...

  8. P2598 [ZJOI2009]狼和羊的故事(最小割)

    P2598 [ZJOI2009]狼和羊的故事 题目描述 “狼爱上羊啊爱的疯狂,谁让他们真爱了一场:狼爱上羊啊并不荒唐,他们说有爱就有方向......” Orez听到这首歌,心想:狼和羊如此和谐,为什么 ...

  9. P2598 [ZJOI2009]狼和羊的故事(网络流)

    P2598 [ZJOI2009]狼和羊的故事 源点和所有狼连 $inf$ 的边 所有羊和汇点连 $inf$ 的边 所有点向四周连 $1$ 的边 这样所有狼和羊之间的边都被割掉了 统计最小割就好辣 #i ...

随机推荐

  1. Java日志介绍(3)-Logback

    Logback 继承自Log4j,它建立在有十年工业经验的日志系统之上.它比其它所有的日志系统更快并且更小,包含了许多独特并且有用的特性. 1.配置 1.1.加载配置 Logback能够在初始化期间自 ...

  2. springcloud vue.js 前后分离 微服务 分布式 activiti工作流 集成代码生成器 shiro权限

    1.代码生成器: [正反双向](单表.主表.明细表.树形表,快速开发利器)freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本.处理类.service等完整模块2. ...

  3. SAP Basis DEBUG改表数据权限角色设计

    SAP Basis DEBUG改表数据权限角色设计 项目实践中,因种种原因不得不要通过debug才能解决一些特定的问题,所以就涉及到了debug权限角色的定义了. DEBUG的权限,无非就是: 1)数 ...

  4. GitLab Container Registry

    通过将GitLab Container Registry集成到GitLab中,每个项目都可以拥有自己的空间来存储其Docker镜像. 1. 启用Container Registry 如果在你的项目的侧 ...

  5. The server cannot be started because one or more of the ports are invalid. Open the server editor and correct the invalid ports.

    在eclipse里运行jsp文件最初迟迟没有反应,重启报了这个错误,tomcat的端口设置有问题.需要打开服务器设置一下端口号. 点击Servers,如果没有这一项,按照Window-Show Vie ...

  6. 【JZOJ 5048】【GDOI2017模拟一试4.11】IQ测试

    题目大意: 判断一个序列是否是另外一个序列删除若干个数字之后得到的. 正文: 我们可以定义两个指针,分别指向长序列和短序列. 拿样例来举例: 如果指针指的数相同,两个指针都往右跳: 如果不同,则指向长 ...

  7. Python中autoescape标签使用详解

    1.spaceless标签:移除html标签中的空白字符.包括空格.tab键.换行符,示例代码如下: {% spaceless %}具体内容{% endspaceless %} 2.autoescap ...

  8. #《Essential C++》读书笔记# 第七章 异常处理

    基础知识 异常处理机制有两个主要成分:异常的鉴定和发出,以及异常的处理方式.通常,不论是membe function和non-member function,都有可能产生异常以及处理异常.异常出现后, ...

  9. vue-socket.io跨域问题的解决方法

    报错信息: Access to XMLHttpRequest at 'http://192.168.37.130:5050/socket.io/?EIO=3&transport=polling ...

  10. P5367 【模板】康托展开

    我们的生活充满了未知与玄学 ---------------------------------------- 链接:P5367 ------------------------------------ ...