bzoj 1001狼抓兔子(对偶图+最短路)最大流
题目
现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,
而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: 左上角点为(,),右下角点为(N,M)(上图中N=,M=).有以下三种类型的道路
:(x,y)<==>(x+,y)
:(x,y)<==>(x,y+)
:(x,y)<==>(x+,y+)
道路上的权值表示这条路上最多能够通过的兔子数,道路是无向的. 左上角和右下角为兔子的两个窝,
开始时所有的兔子都聚集在左上角(,)的窝里,现在它们要跑到右下解(N,M)的窝中去,狼王开始伏击
这些兔子.当然为了保险起见,如果一条道路上最多通过的兔子数为K,狼王需要安排同样数量的K只狼,
才能完全封锁这条道路,你需要帮助狼王安排一个伏击方案,使得在将兔子一网打尽的前提下,参与的
狼的数量要最小。因为狼还要去找喜羊羊麻烦.
Input 第一行为N,M.表示网格的大小,N,M均小于等于1000.
接下来分三部分
第一部分共N行,每行M-1个数,表示横向道路的权值.
第二部分共N-1行,每行M个数,表示纵向道路的权值.
第三部分共N-1行,每行M-1个数,表示斜向道路的权值.
输入文件保证不超过10M
Output 输出一个整数,表示参与伏击的狼的最小数量. Sample Input Sample Output
题目图片

讲这部分之前,请先阅读以上的文章(讲得十分好%%%)(当然阅读到27页就好了)
读完后,我们发现这道题完全可以用其对偶图来跑最短路。
原图 对偶图
面数 x 面数 y
点数 y 那么其对偶图中 点数 x
边数 z 边数 z
面数和点数正好相反。
将原图的起点和终点连接起来,建立一个新的面(这是必须的)。

当然s点和t点之间是没有边的。
s和1,7,9,11之间有边。
t和2,4,6,12之间有边。
上面是我们建好的对偶图,从左至右依次编号,关于对偶图中面的编号,因为我们是按照横边,纵边,斜边的顺序读入的,所以我们一定要按照一定的方法对这些图编号
我采用的是从左至右依次编号,因为我们可以很清楚当前边连接的两个点(原图中的两个面)所在的位置,因为这是平面图,所以可以用欧拉公式来求出之前有多少点(
原图中的面)。再加上这个点(原图中的面(重要的事说三遍))在当前行中的位置就是它的编号。
只要原图中的两个面之间存在边,那么它的对偶图中的两个点就存在边。
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int cnt, i, j, x, xx, xxx, h, t, s, hh[], n, m, w;
bool dd[];
int e, l[], d[], hhh, ww;
struct node
{
int v, next, z;
} b[];
inline void add(int aa, int bb, int cc)//邻接表,建双向边
{
b[++cnt].v = bb;
b[cnt].next = hh[aa];
b[cnt].z = cc;
hh[aa] = cnt;
b[++cnt].v = aa;
b[cnt].next = hh[bb];
b[cnt].z = cc;
hh[bb] = cnt;
}
void add1()
{
for(i = ; i < m; ++i)
{
scanf("%d", &x);
add(i * , t, x);
}
for(i = ; i < n; ++i)
{
for(j = ; j < m; ++j)
{
scanf("%d", &x);
add((i - ) * (m - ) * + j * , (i - ) * (m - ) * + j * - m * + , x);//利用欧拉公式确定编号并建边(下面的add函数也是如此)
}
}
for(j = ; j < m; ++j)
{
scanf("%d", &x);
add(s, (n - ) * * (m - ) + j * - , x);
}
}
void add2()
{
for(i = ; i < n; ++i)
{
scanf("%d", &x);
xx = (i - ) * (m - ) * + ;
add(s, xx, x);
for(j = ; j < m; ++j)
{
scanf("%d", &x);
xx += ;
add(xx - , xx, x);
}
scanf("%d", &x);
add(xx + , t, x);
}
}
inline void add3()
{ for(i = ; i < n; ++i)
{
for(j = ; j < m; ++j)
{
scanf("%d", &x);
add((i - ) * (m - ) * + j * , (i - ) * (m - ) * + j * - , x);
}
}
}
//下面的spfa中一定要用循环队列,省空间。不用的话空间开小(这很有可能毕竟1百万个点)可能会被卡。
void spfa()
{
dd[s] = true;
h = ;
w = ;
memset(l,0x3f,sizeof(l));//将l数组赋成最大值
//hhh记录的是我们用的是队列中第几个元素(实际上)
//ww记录的是队列中总共有几个元素
l[s] = ;
while()
{
if(hhh > ww)break;
h = hhh % ;
w = ww % ;
for(i = hh[s]; i; i = b[i].next)
{
e = b[i].v;
if(l[s] + b[i].z < l[e])
{
l[e] = l[s] + b[i].z;
if(!dd[e])w = ww % , d[++w] = e, ww++, dd[e] = true;
}
}
dd[s] = false;
h = hhh % ;
s = d[++h];
hhh++;
}
}
int main()
{
scanf("%d %d", &n, &m);
if(n == m && n == )//特判
{
printf("");
return ;
}
s = ;
t = * (n - ) * (m - ) + ;
add1();//读入横边
add2();//读入纵边
add3();//读入斜边
spfa();//对其对偶图求s————t的最短路
printf("%d", l[t]);
return ;
}
bzoj 1001狼抓兔子(对偶图+最短路)最大流的更多相关文章
- BZOJ 1001 狼抓兔子 (最小割转化成最短路)
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 27715 Solved: 7134[Submit][ ...
- BZOJ 1001--[BeiJing2006]狼抓兔子(最短路&对偶图)
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 29035 Solved: 7604 Descript ...
- 【BZOJ1001】[BeiJing2006]狼抓兔子 对偶图最短路
[BZOJ1001][BeiJing2006]狼抓兔子 Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子 ...
- BZOJ 1001 - 狼抓兔子 - [Dinic最大流][对偶图最短路]
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1001 Description现在小朋友们最喜欢的"喜羊羊与灰太狼", ...
- BZOJ 1001 狼抓兔子 (网络流最小割/平面图的对偶图的最短路)
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 算法讨论: 1.可以用最大流做,最大流等于最小割. 2.可以把这个图转化其对偶图,然 ...
- bzoj 1001 狼抓兔子 —— 平面图最小割(最短路)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1001 平面图最小割可以转化成最短路问题: 建图时看清楚题目的 input ... 代码如下: ...
- BZOJ 1001 狼抓兔子 平面图的最小割
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1001 题目大意: 见链接 思路: 求最小割,平面图的最小割等价于对偶图的最短路 直接建 ...
- BZOJ 1001 狼抓兔子
链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子 ...
- bzoj1001狼抓兔子 对偶图优化
bzoj1001狼抓兔子 对偶图优化 链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1001 思路 菜鸡总是要填坑的! 很明显让你求网格图的最 ...
随机推荐
- TDR分辨率
在日常的生活工作中,有很多测试测量的工具,比如测量长度的尺子,计量时间的钟表等等,谈到测试测量工具的时候,分辨率是关键指标之一,比如尺子的 分辨率是1mm,时钟的分辨率是秒.所谓分辨率就是测试测量工具 ...
- 2013 duilib入门简明教程 -- VS环境配置(2)
既然是入门教程,那当然得基础点,因为搜索duilib相关资料时,发现有些小伙伴到处都是编译错误,以及路径配置错误等等,还有人不知道SVN,然后一个个文件手动下载的. 其实吧,duili ...
- 2013 duilib入门简明教程 -- FAQ (19)
虽然前面的教程几乎把所有的知识点都罗列了,但是有很多问题经常在群里出现,所以这里再次整理一下. 需要注意的是,在下面的问题中,除了加上XML属性外,主窗口必须继承自WindowImpl ...
- Python标准库的threading.Thread类(转自别人的翻译)
这个类表示在单独的控制线程中运行的活动.有两种方法可以指定这种活动,给构造函数传递回调对象,或者在子类中重写run() 方法.其他方法(除了构造函数)都不应在子类中被重写.换句话说,在子类中只有__i ...
- 应用程序框架实战三十三:表现层及ASP.NET MVC介绍(二)
最近的更新速度越来越慢,主要是项目上比较忙,封装EasyUi也要花很多时间.不过大家请放心,本系列不会半途夭折,并且代码干货也会持续更新.本文继续介绍表现层和Asp.net Mvc,我将在本篇讨论一些 ...
- 遇到 HTTP 错误 403.14 - Forbidden?
打开 http://localhost:1609 报错: HTTP 错误 403.14 - Forbidden Web 服务器被配置为不列出此目录的内容 解决方案一:设置默认首页 在 Web.conf ...
- 在ubuntu server中安装和配置docker
经过一段时间针对不同版本的学习,现在总结当前最新的安装配置过程(应该也是比较简单的) 如果不清楚什么是docker,请参考 https://www.docker.com/ 准备工作 建议在安装之前运行 ...
- Rust初步(一):介绍
最近在研究Rust这个新的语言.那么Rust是什么呢? Rust是一个注重安全与速度的现代系统编程语言,通过在没有垃圾回收的情况下保证内存安全来实现它的目标,这使它成为一个在很多其它语言不适合的用例中 ...
- react+redux教程(二)redux的单一状态树完全替代了react的状态机?
上篇react+redux教程,我们讲解了官方计数器的代码实现,react+redux教程(一).我们发现我们没有用到react组件本身的state,而是通过props来导入数据和操作的. 我们知道r ...
- OracleDBA之用户管理
再分享一下Oracle中对用户的管理,以下这些东西是我的麦库上存的当时学Oracle的学习笔记今天拿出来和大家分享一下,转载请注明出处,下面用的Oracle的版本是10g,用的时WinServer20 ...