Description

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

左上角点为(1,1),右下角点为(N,M)(上图中N=4,M=5).有以下三种类型的道路
1:(x,y)<==>(x+1,y)
2:(x,y)<==>(x,y+1)
3:(x,y)<==>(x+1,y+1)
道路上的权值表示这条路上最多能够通过的兔子数,道路是无向的. 左上角和右下角为兔子的两个窝,
开始时所有的兔子都聚集在左上角(1,1)的窝里,现在它们要跑到右下解(N,M)的窝中去,狼王开始伏击
这些兔子.当然为了保险起见,如果一条道路上最多通过的兔子数为K,狼王需要安排同样数量的K只狼,
才能完全封锁这条道路,你需要帮助狼王安排一个伏击方案,使得在将兔子一网打尽的前提下,参与的
狼的数量要最小。因为狼还要去找喜羊羊麻烦.

Input

第一行为N,M.表示网格的大小,N,M均小于等于1000.
接下来分三部分
第一部分共N行,每行M-1个数,表示横向道路的权值.
第二部分共N-1行,每行M个数,表示纵向道路的权值.
第三部分共N-1行,每行M-1个数,表示斜向道路的权值.
输入文件保证不超过10M

Output

输出一个整数,表示参与伏击的狼的最小数量.

Sample Input

3 45 6 44 3 17 5 35 6 7 88 7 6 55 5 56 6 6

Sample Output

14

Solution

最小割–>網絡流水題
Dinic中的剪枝優化一定要用全. 三個優化都已經在代碼中標明.

#include<cstdio>
#include<cctype>
#include<cstring>
#include<climits>
#include<algorithm>
using namespace std;
inline int read()
{int x = 0, flag = 1;;char c;while(! isgraph(c = getchar()))if(c == '-')flag *= - 1;while(isgraph(c))x = x * 10 + c - '0', c = getchar();return x * flag;
}
void print(int x)
{if(x < 0)putchar('-'), x *= - 1;if(x == 0)putchar('0');int ans[10], top = 0;while(x)ans[top ++] = x % 10, x /= 10;for(; top; top --)putchar(ans[top - 1] + '0');
}
const int oo = INT_MAX;
const int MAXN = 1 << 10, MAXM = 1 << 10;
int top;
struct Edge
{int v, flow, next;Edge(){}Edge(int v, int flow, int next): v(v), flow(flow), next(next){}
}G[MAXN * MAXM << 3];
int head[MAXN * MAXM];
void add_edge(int u, int v, int flow)
{G[top] = Edge(v, flow, head[u]);head[u] = top ++;
}
int Q[MAXN * MAXM];
int dep[MAXN * MAXM];
inline int BFS(int s, int t)
{int L = 0, R = 1;Q[L] = s;memset(dep, - 1, sizeof(dep));dep[s] = 0;while(L < R){int u = Q[L];for(int i = head[u]; i != - 1; i = G[i].next)if(dep[G[i].v] == - 1 && G[i].flow){dep[G[i].v] = dep[u] + 1, Q[R ++] = G[i].v;if(G[i].v == t)     //優化③ return 1;}L ++;}return 0;
}
inline int DFS(int u, int flow, int t)
{if(u == t)return flow;int flow_sum = 0;for(int i = head[u]; i != - 1; i = G[i].next){int v = G[i].v;if(G[i].flow && dep[v] == dep[u] + 1){int cur_flow = min(G[i].flow, flow - flow_sum);cur_flow = DFS(v, cur_flow, t);flow_sum += cur_flow;G[i].flow -= cur_flow;G[i ^ 1].flow += cur_flow;if(flow_sum == flow)    //優化②, 也是最主要的優化 return flow; }}if(! flow_sum)  //優化① dep[u] = - 1; return flow_sum;
}
int main()
{#ifndef ONLINE_JUDGEfreopen("BZOJ1001.in", "r", stdin);freopen("BZOJ1001.out", "w", stdout);#endifint n = read(), m = read();top = 0;memset(head, - 1, sizeof(head));for(int i = 0; i < n; i ++)for(int j = 1; j < m; j ++){int flow = read();add_edge(i * m + j, i * m + j - 1, flow),add_edge(i * m + j - 1, i * m + j, flow);}for(int i = 1; i < n; i ++)for(int j = 0; j < m; j ++){int flow = read();add_edge(m * i + j, m * (i - 1) + j, flow);add_edge(m * (i - 1) + j, m * i + j, flow);}for(int i = 1; i < n; i ++)for(int j = 1; j < m; j ++){int flow = read();add_edge(m * i + j, m * (i - 1) + j - 1, flow);add_edge(m * (i - 1) + j - 1, m * i + j, flow);}int flow = 0;while(BFS(0, n * m - 1))flow += DFS(0, oo, n * m - 1);print(flow);
}

转载于:https://www.cnblogs.com/ZeonfaiHo/p/6402830.html

BZOJ1001[BeiJing2006]狼抓兔子最小割網絡流相关推荐

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

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

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

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

  3. bzoj1001 [BeiJing2006]狼抓兔子(最小割/平面图最大流转对偶图最短路)

    首先这题显然就是求一个最小割.然后跑dinic加点优化也是可以过的. 这题还有一种更妙的做法:st平面图最大流转对偶图最短路.大概做法就是首先在原图中加一条s->t的边,然后把原图的一个面当作一 ...

  4. [BZOJ1001]: [BeiJing2006]狼抓兔子

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

  5. bzoj1001:[BeiJing2006]狼抓兔子

    传送门 最小割,一眼最小割,这个甚至不需要建什么模型,直接按它给的建就好了,最小割=最大流,跑个最大流就行了,注意:图是无向图 #include<cstdio> #include<q ...

  6. BZOJ1001 [BeiJing2006]狼抓兔子 (网络流)

    题意分析 一看就是一道网络流的题目,然后上去最大流直接搞. 然后发现超时了,所以学了一波当前弧优化,然后就过了. 然后我觉得还可以再快一点,就IO加速了一下, 发现速度提高了400ms. 嗯,FAST ...

  7. 【BZOJ1001】狼抓兔子题解

    BZOJ1001: [BeiJing2006]狼抓兔子 Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还 ...

  8. BZOJ 1001: [BeiJing2006]狼抓兔子【最大流/SPFA+最小割,多解】

    1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec  Memory Limit: 162 MB Submit: 23822  Solved: 6012 [Submit ...

  9. 【BZOJ1001】狼抓兔子

    [BZOJ1001]狼抓兔子 题面 bzoj 题解 懒得平面图转对偶图了,直接最小割板子加优化. #include <iostream> #include <cstdio> # ...

最新文章

  1. Linux 第60,61天 ansible的playbook
  2. 【LeetCode】0938. 二叉搜索树的范围和(二叉树的遍历)
  3. [云炬ThinkPython阅读笔记]3.4 增加新函数
  4. NET下,你采用的是哪种方式进行数据操作?
  5. Intent中各种常见的Action
  6. [蓝桥杯][2017年第八届真题]k倍区间(数学+思维)
  7. 大脑比机器智能_机器大脑的第一步
  8. 从像素坐标到相机坐标_多视图几何基础——深入理解相机内外参数
  9. 【jvm】jvm 执行模式设置
  10. win98模拟器_安利一款安卓win98模拟小游戏
  11. PHP调试工具 - FirePHP安装与使用方法
  12. oracle销售合同管理,Oracle服务合同管理系统11i
  13. 各品牌智能电视刷机怎么寻找对应固件包?详细图文教程分享
  14. python读取yml文件
  15. 手把手教你下载ILSVRC2012(ImageNet2012)分类部分数据集以及使用Pytorch训练
  16. 糖尿病11年的隔壁老王
  17. java打印 X XXX XXXXX
  18. 【洛谷】P1008 [NOIP1998 普及组] 三连击
  19. 关于elementui上传图片 隐藏上传按钮
  20. 视频教程-最新完整react教程从入门到精通包教包会-ReactJS

热门文章

  1. 数据分析 python 用途-Python 从爬虫到数据分析
  2. python可以在线编程吗-有哪些 python 的在线练习题或编程挑战的网站?
  3. python读取excel表格-python读写Excel表格的实例代码(简单实用)
  4. 零基础自学python的建议-如何从零基础自学Python?
  5. python基础教程pdf百度云-《Python基础教程(第3版)》PDF高清版
  6. python3语法-python3 标签语法有什么用?
  7. python安装包多大-如何查看安装的pip包大小?
  8. python400教程全集免费-千锋出品全套python视频教程,400大全集,你了解吗?
  9. python turtle画彩虹-Python turtle 绘制彩色螺旋线
  10. 运行python需要网吗-python搭建网站(想学Python有什么建议吗?)