题目大意

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

左上角点为 (1, 1),右下角点为 (N, M) (上图中N=4, M=4)。有以下三种类型的道路

  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 只狼,才能完全封锁这条道路,你需要帮助狼王安排一个伏击方案,使得在将兔子一网打尽的前提下,参与的狼的数量要最小。因为狼还要去找喜羊羊麻烦。

N, M 均小于等于 1000

做法分析

一看就是最小割问题,写的比较好的网络流可以直接暴力的搞过去,当然,正解肯定不是这样,虽然是一个水题,不过还是值得一做的

这题需要利用平面图的对偶图性质

平面图的对偶图很好构造:

  将原图中的面变成新图中的点

  原图中,每条边必定分割了两个面,在新图中,对应的点之间添加一条边,边权还是原图中边的边权

在原图中的一个全局的割就对应了新图中的一个环,也就是说,如果想要求原图中的一个全局最小割,只需要在新图中找一个最小环即可

怎么求出原图中分割固定点 s 和 t(s 和 t 处于一个无线大的平面的边缘) 的一个最小割呢?

  先在原图中添加 s 到 t 的边,给原图增加了一个面

  构造原图的对偶图,把由于增边而增加的新面对应的点设为 S,无穷大的平面对应的点设为 T

  删掉对偶图中 S 到 T 直接相连的边

  求出 S 到 T 的最短路就可以了

详细请看周冬的论文 《两极相通——浅析最大—最小定理在信息学竞赛中的应用》

这题按照上面将的建图,跑最短路就行了,听说 SPFA 也能过,我没试过,用的堆优化的 Dijkstra + 输入外挂直接 516ms 过掉

参考代码

 #include <iostream>
#include <cstring>
#include <cstdio>
#include <queue> using namespace std; const int N=, INF=0x3fffffff, E=N*; struct ARC {
int u, val, next;
inline void init(int a, int b, int c) {
u=a, val=b, next=c;
}
} arc[E];
int head[N], tot, S, T, n, m, dis[N];
bool vs[N]; struct data {
int u, dis;
data() {}
data(int a, int b) : u(a), dis(b) {}
bool operator < (const data &T) const {
return dis>T.dis;
}
}; inline void add_arc(int s, int t, int val) {
arc[tot].init(t, val, head[s]);
head[s]=tot++;
} priority_queue <data> Q;
void Dijkstra() {
fill(dis, dis+T+, INF);
fill(vs, vs+T+, );
while(!Q.empty()) Q.pop();
dis[S]=, Q.push(data(S, ));
for(int u; !Q.empty(); ) {
u=Q.top().u, Q.pop();
if(vs[u]) continue;
if(u==T) {
printf("%d\n", dis[T]);
break;
}
vs[u]=;
for(int e=head[u]; e!=-; e=arc[e].next) {
int v=arc[e].u;
if(vs[v] || dis[u]+arc[e].val>=dis[v]) continue;
dis[v]=dis[u]+arc[e].val;
Q.push(data(v, dis[v]));
}
}
} void read(int &x) {
char c;
while((c=getchar())<'' || c>'');
x=c-'';
while((c=getchar())>='' && c<='') x=(x<<)+(x<<)+c-'';
} void Input() {
for(int i=, id1, id2, a; i<=n-; i++)
for(int j=; j<=m-; j++) {
read(a);
id1=((i-)*(m-)+j)*-;
id2=(i*(m-)+j)*;
if(i==) id1=T;
else if(i==n-) id2=S;
add_arc(id1, id2, a);
add_arc(id2, id1, a);
} for(int i=, id1, id2, a; i<=n-; i++)
for(int j=; j<m; j++) {
read(a);
id1=((i-)*(m-)+j)*;
id2=((i-)*(m-)+j+)*-;
if(j==) id1=S;
else if(j==m-) id2=T;
add_arc(id1, id2, a);
add_arc(id2, id1, a);
} for(int i=, id1, id2, a; i<=n-; i++)
for(int j=; j<=m-; j++) {
read(a);
id1=((i-)*(m-)+j)*;
id2=((i-)*(m-)+j)*-;
add_arc(id1, id2, a);
add_arc(id2, id1, a);
}
} int main() {
read(n), read(m);
S=, T=(n-)*(m-)*+;
fill(head, head+T+, -), tot=;
if(n== || m==) {
if(n>m) swap(n, m);
int ans=INF;
for(int i=, a; i<m; i++) {
read(a);
if(ans>a) ans=a;
}
printf("%d\n", ans==INF?:ans);
}
else Input(), Dijkstra();
return ;
}

BZOJ 1001

题目链接 & AC 通道

BZOJ 1001 [BeiJing2006] 狼抓兔子

BZOJ 1001 [BeiJing2006] 狼抓兔子(平面图最大流)的更多相关文章

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

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

  2. bzoj 1001: [BeiJing2006]狼抓兔子 平面图最小割

    平面图跑最大流 可以转换为其对偶图跑最短路 一个环对应一个割  找到最小环(即最短路)极为所求,注意辅助边的建立 加入读入优化  不过时间还是一般  估计是dij写的不好   大神勿喷~~~ /*** ...

  3. BZOJ 1001: [BeiJing2006]狼抓兔子

    1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 20029  Solved: 4957[Submit][ ...

  4. BZOJ 1001 [BeiJing2006]狼抓兔子 (UVA 1376 Animal Run)

    1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 24727  Solved: 6276[Submit][ ...

  5. BZOJ 1001: [BeiJing2006]狼抓兔子(最短路)

    平面图的最小割转化为对偶图的最短路(资料:两极相通——浅析最大最小定理在信息学竞赛中的应用) ,然后DIJKSTRA就OK了. ------------------------------------ ...

  6. BZOJ 1001: [BeiJing2006]狼抓兔子 最小割

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓 ...

  7. 【刷题】BZOJ 1001 [BeiJing2006]狼抓兔子

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

  8. [bzoj 1001][Beijing2006]狼抓兔子 (最小割+对偶图+最短路)

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

  9. BZOJ 1001: [BeiJing2006]狼抓兔子(s-t平面图+最短路求最小割)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1001 题意: 思路:这道题目是最小割题目,但是吧你直接套用Dinic是会超时的. 这里有种很奇妙的做 ...

随机推荐

  1. [游戏学习26] MFC 时间函数 画图形

    >_<:这里第一次介绍MFC的时间函数,功能和Win32里的计时器类似. >_<:这里还介绍了MFC的图形绘制函数,和Win32有一点区别 >_<:ABC.h #d ...

  2. Gradle的属性设置大全

    Gradle作为一款项目构建工具,由于其强大.灵活.快速.完全兼容Ant等特性,越来越受到人们欢迎.Gradle的灵活有时候也会引起人们的困惑.比如在Gradle中设置变量和属性就有N种办法.由于Gr ...

  3. ASP.NET 5系列教程 (六): 在 MVC6 中创建 Web API

    ASP.NET 5.0 的主要目标之一是统一MVC 和 Web API 框架应用. 接下来几篇文章中您会了解以下内容: ASP.NET MVC 6 中创建简单的web API. 如何从空的项目模板中启 ...

  4. 有关HTML5 Video对象的ontimeupdate事件的问题

    日前在做一个视频播放的页面,其中用到了HTML5的Video对象,这个是HTML5中新增的一个对象,支持多种不同格式的视频在线播放,功能比较强大,而且还扩展了许多事件,可以通过JavaScript脚本 ...

  5. LEA指令

    格    式:LEA OPRD1,OPRD2 功    能:将有效地址传送到指定的的寄存器 OPRD1 为目的操作数,可为任意一个16位的通用寄存器. OPRD2 为源操作数,可为变量名.标号或地址表 ...

  6. 秀才提笔忘了字:javascript使用requestAnimationFrame实现动画

    requestAnimationFrame优于setTimeout/setInterval的地方在于它是由浏览器专门为动画提供的API,在运行时浏览器会自动优化方法的调用,并且如果页面不是激活状态下的 ...

  7. paip.提升效率--调试--日志系统日志参数含义---python

    paip.提升效率--调试--日志系统日志参数含义---python #同时向控制台和文件输出日志 #日志参数含义 import logging log_format = '%(filename)s ...

  8. java继承与多态-3个小题

    1.(1)编写一个接口ShapePara,要求: 接口中的方法: int getArea():获得图形的面积.int getCircumference():获得图形的周长 (2)编写一个圆类Circl ...

  9. layer-list实现只有左、右和下边框的圆角矩形

    项目中需要实现如下效果的布局 也就是一个左右下角带圆角,上方不带圆角的白色背景矩形,而且只有左.右和下边框,颜色为浅灰色. 当然,切一个.9图片作为背景也能实现,但是能用代码实现的还是尽量用代码实现, ...

  10. [Aaronyang] 写给自己的WPF4.5 笔记20 [3d课 1/4]

    假设你是高中毕业的,ok,数学知识几何知识中,我们学过  x,y,z   3个轴然后就可以画出形状了. 1. 新建空白窗体,grid换成canvas,然后新增一个Viewport3D元素 3d中显示的 ...