传送门

洛谷

Solution

直接跑最小割板子就好了。

代码实现

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#include<queue>
#include<set>
#include<map>
#include<iostream>
using namespace std;
#define ll long long
#define re register
#define file(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout)
inline int gi()
{int f=1,sum=0;char ch=getchar();while(ch>'9' || ch<'0'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0' && ch<='9'){sum=(sum<<3)+(sum<<1)+ch-'0';ch=getchar();}return f*sum;
}
const int N=1000010,NN=1001,Inf=1e9+10;
int id[NN][NN],front[N],cnt,cur[N];
int dep[N],s,t,n,m,tot,sum;
struct node
{int to,nxt,w;
}e[12000000];
void Add(int u,int v,int w)
{e[cnt]=(node){v,front[u],w};front[u]=cnt++;e[cnt]=(node){u,front[v],w};front[v]=cnt++;
}
queue<int>Q;
bool bfs()
{memset(dep,0,sizeof(dep));dep[s]=1;Q.push(s);while(!Q.empty()){int u=Q.front();Q.pop();for(int i=front[u];i!=-1;i=e[i].nxt){int v=e[i].to;if(!dep[v] && e[i].w){dep[v]=dep[u]+1;Q.push(v);}}}return dep[t];
}
int dfs(int u,int flow)
{if(u==t || !flow)return flow;for(int &i=cur[u];i!=-1;i=e[i].nxt){int v=e[i].to;if(dep[v]==dep[u]+1 && e[i].w){int di=dfs(v,min(e[i].w,flow));if(di){e[i].w-=di;e[i^1].w+=di;return di;}else dep[v]=0;}}return 0;
}
int Dinic()
{int flow=0;while(bfs()){for(int i=s;i<=t;i++)cur[i]=front[i];while(int d=dfs(s,Inf))flow+=d;}return flow;
}
int main()
{n=gi();m=gi();memset(front,-1,sizeof(front));for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)id[i][j]=++tot;t=tot++;Add(s,id[1][1],Inf);Add(id[n][m],t,Inf);for(int i=1;i<=n;i++)for(int j=1;j<m;j++){int x=gi();Add(id[i][j],id[i][j+1],x);Add(id[i][j+1],id[i][j],x);}for(int i=1;i<n;i++)for(int j=1;j<=m;j++){int x=gi();Add(id[i][j],id[i+1][j],x);Add(id[i+1][j],id[i][j],x);}for(int i=1;i<n;i++)for(int j=1;j<m;j++){int x=gi();Add(id[i][j],id[i+1][j+1],x);Add(id[i+1][j+1],id[i][j],x);}printf("%d\n",Dinic()/2);return 0;
}

转载于:https://www.cnblogs.com/mle-world/p/10555689.html

【洛谷4001】 [ICPC-Beijing 2006]狼抓兔子(最小割)相关推荐

  1. BZOJ1001[BeiJing2006]狼抓兔子——最小割

    题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...

  2. BZOJ1001[BeiJing2006]狼抓兔子最小割網絡流

    Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一 ...

  3. BZOJ 1001[BeiJing2006]狼抓兔子 最小割转最短路

    Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一 ...

  4. 洛谷 P4001 [ICPC-Beijing 2006]狼抓兔子

    题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...

  5. P4001 [ICPC-Beijing 2006]狼抓兔子(ISAP模板题)

    传送门 题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的 ...

  6. 【洛谷1361】 小M的作物(最小割)

    传送门 洛谷 Solution 这是一个比较实用的套路,很多题目都有用,而且这个套路难以口胡出来. 考虑把每一个附加贡献重新建一个点,然后向必需的点连边,流量为val. 然后直接种植的从源点向这个点连 ...

  7. 洛谷 - P4001 [ICPC-Beijing 2006]狼抓兔子(网格图最大流转换为对偶图最短路)

    题目链接:点击查看 题目大意:给出一张 n * m 的稠密图,求以点 ( 1 , 1 ) 为起点,点 ( n , m ) 为终点的最小割 题目分析:n 和 m 都是 1e3 级别的,最多可能有 1e6 ...

  8. P4001-[ICPC-Beijing 2006]狼抓兔子【对偶图】

    正题 题目链接:https://www.luogu.com.cn/problem/P4001 题目大意 给出一个类似于 的网格图,求起点到终点的最小割. 解题思路 最小割直接跑网络流,然后发现dini ...

  9. 狼抓兔子(平面图转对偶图)

    狼抓兔子(平面图转对偶图) 面对下面这样一个网格的地形: 道路上的权值表示这条路上最多能够通过的兔子数,道路是无向的. 左上角和右下角为兔子的两个窝,开始时所有的兔子都聚集在左上角(1,1)的窝里,现 ...

最新文章

  1. python和前端之HTML的激情
  2. 最终产品的质量需求是什么?
  3. matlab遍历cell和array的for循环写法
  4. iview form 表单 自定义参数验证 validate
  5. Java实现身份证号码的验证,JAVA后台验证身份证号码
  6. 飞特商城后台管理系统是接私活利器,企业级快速开发框架 商城后台 取之开源,用之开源
  7. python 切片函数,python切片详解
  8. String.Format用法
  9. 如何使用本地账户完整安装 SharePoint Server
  10. java位图去重_Redis系列(3) Bloom/BitMap/Geo
  11. 基于JWT前后端token认证
  12. C++ 实现matlab高斯滤波函数imgaussfilt
  13. 新唐 Nuvoton ML51PC 入门 点亮板载LED
  14. maven deploy jar包和源码包到私服
  15. 新疆电大计算机考试纸质版,2021年度电大计算机网考纸质题库考前必看题.doc
  16. 《JAVA语言程序设计》期末考试试题及答案
  17. 1026. 多米诺和三格骨牌铺瓦问题
  18. 计算机品牌企业关系图,AJ71C24-S3 画出PLC的I/O点与输入/输出设备的连接图或对应关系表, 三菱AJ71C24-S3 - 广州凌控...
  19. 在嵌入式板子ARMv7 上利用neon对彩色图转换为灰度图进行加速
  20. 7 Workflow

热门文章

  1. java 日期处理 口诀_java时间处理常用方法工具类
  2. java 子类重定义变量_java子类对象和成员变量的隐写方法重写
  3. 使用git向码云上提交代码
  4. springmvc配置ssl_spring MVC配置详解
  5. 华为eNSP模拟器上实现FTP服务
  6. Statement对象
  7. 2017面试分享(js面试题记录)
  8. HDU1283 最简单的计算机【模拟】
  9. 智能家居市场需求矛盾深层原因分析
  10. Node.js 切近实战(十一) 之实时通讯