BZOJ_1001_狼抓兔子_(平面图求最小割+对偶图求最短路)
描述
http://www.lydsy.com/JudgeOnline/problem.php?id=1001
1001: [BeiJing2006]狼抓兔子
Time Limit: 15 Sec Memory Limit: 162 MB
Submit: 17068 Solved: 4171
[Submit][Status][Discuss]
Description

Input
Output
输出一个整数,表示参与伏击的狼的最小数量.
Sample Input
5 6 4
4 3 1
7 5 3
5 6 7 8
8 7 6 5
5 5 5
6 6 6
Sample Output
HINT
2015.4.16新加数据一组,可能会卡掉从前可以过的程序。
Source
分析
平面图求最小割,转化成对偶图求最短路,经典.
注意:
1.优先队列是个大根堆.
2.Dijkstra可以带一个vis数组,也可以不带,因为一个点出来以后,它更新的的点和原本就在队列里的点都比它大,所以它不可能被更新得更小,之后这个点再出队时情况不比第一次更优,所以出队也不会有操作.
3.双向边,数组要开够(貌似不是第一次犯这个错误).
4.网上有人说m==1||n==1的情况可以不特判,在get函数中已经可以处理妥当,大丈夫.
#include <cstdio>
#include <queue>
#include <algorithm>
using namespace std; const int maxn=+,oo=<<;
int n,m,cnt;
int d[maxn*maxn*],head[maxn*maxn*];
bool vis[maxn*maxn*];
struct edge{
int to,w,next;
edge(){}
edge(int a,int b,int c):to(a),w(b),next(c){}
bool operator<(const edge &a) const { return a.w<w; }
}g[maxn*maxn*];
void insert(int from,int to,int w){
g[++cnt]=edge(to,w,head[from]); head[from]=cnt;
g[++cnt]=edge(from,w,head[to]); head[to]=cnt;
} int get(int x,int y,int z){
if(x<||y>=m) return ((n-)*(m-)<<)+;
if(x>=n||y<) return ;
return (((x-)*(m-)+y-)<<)+z+;
}
int Dijkstra(int s,int t){
for(int i=;i<=((n-)*(m-)<<)+;i++) d[i]=oo;
d[s]=;
priority_queue <edge> q;
q.push(edge(s,,));
while(!q.empty()){
edge e=q.top(); q.pop();
int x=e.to;
if(vis[x]) continue;
vis[x]=true;
for(int i=head[x];i;i=g[i].next){
int y=g[i].to;
if(d[y]>d[x]+g[i].w){
d[y]=d[x]+g[i].w;
q.push(edge(y,d[y],));
}
}
}
return d[t];
} void init(){
for(int i=;i<=n;i++){
for(int j=;j<m;j++){
int a; scanf("%d",&a);
insert(get(i,j,),get(i-,j,),a);
}
}
for(int i=;i<n;i++){
for(int j=;j<=m;j++){
int a; scanf("%d",&a);
insert(get(i,j-,),get(i,j,),a);
}
}
for(int i=;i<n;i++){
for(int j=;j<m;j++){
int a; scanf("%d",&a);
insert(get(i,j,),get(i,j,),a);
}
}
} int main(){
scanf("%d%d",&n,&m);
init();
printf("%d\n",Dijkstra(,((n-)*(m-)<<)+));
return ;
}
BZOJ_1001_狼抓兔子_(平面图求最小割+对偶图求最短路)的更多相关文章
- BZOJ1001: [BeiJing2006]狼抓兔子(优化的dinic或转化对偶图求最短路)
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 30078 Solved: 7908[Submit][ ...
- 【BZOJ1001】狼抓兔子(平面图转对偶图,最短路)
[BZOJ1001]狼抓兔子(平面图转对偶图,最短路) 题面 BZOJ 洛谷 题解 这题用最小割可以直接做 今天再学习了一下平面图转对偶图的做法 大致的思路如下: 1.将源点到汇点中再补一条不与任何线 ...
- [bzoj1001][BeiJing2006]狼抓兔子_网络流_最小割转对偶图
狼抓兔子 bzoj-1001 BeiJing2006 Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还 ...
- 【Bzoj】1001狼抓兔子(平面图最小割转对偶图最短路)
YEAH 题目链接 终于做对这道题啦 建图的艰辛难以言表- - 顺便说一句我队列转STL啦 狼抓兔子的地图符合平面图定义,于是将该图转成对偶图并求出对偶图的最短路即可. 这篇博客给了我极大的帮助 ...
- BZOJ_2001_[BeiJing2006]狼抓兔子_最小割转对偶图
BZOJ_2001_[BeiJing2006]狼抓兔子 题意:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 分析:思路同NOI2010海拔. ...
- [BeiJing2006]狼抓兔子 dijkstra+平面图最小割
一眼裸的最大流求最小割,然而数据范围过大,跑不下来. 我们可以将平面图转成对偶图,并进行连边. 这样,每条边的长度就对应原图中的割边长度. 起点到终点的最短路即为最小割. 别用SPFA,会死的很惨 C ...
- BZOJ 1001 [BeiJing2006] 狼抓兔子(平面图最大流)
题目大意 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的.而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...
- _bzoj1001 [BeiJing2006]狼抓兔子【平面图】
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 顺便推荐一个ppt,里面有对平面图的介绍:浅析最大最小定理在信息学竞赛中的应用. 这里 ...
- 【BZOJ1001】狼抓兔子(平面图最小割转最短路)
题意:有一张平面图,求它的最小割.N,M.表示网格的大小,N,M均小于等于1000. 左上角点为(1,1),右下角点为(N,M).有以下三种类型的道路 1:(x,y)<==>(x+1,y ...
随机推荐
- c语言学习之基础知识点介绍(十八):几个修饰关键字和内存分区
一.几个修饰关键字 全局变量: 全局变量跟函数一样也分为声明和实现.如果是全局变量,实现在它调用之后,那么需要在调用之前进行声明.注意:全局变量的声明只能写在函数外,写在函数就不是全局变量了而是局部变 ...
- Oracle hextoraw和rawtohex
Oracle hextoraw和rawtohex [日期:2012-07-17] 来源:Linux社区 作者:adrain_001 [字体:大 中 小] HEXTORAW 语法: HEXT ...
- 《JavaScript高级程序设计》 阅读计划
第一周 第1章 JavaScript简介 1 第2章 在Html中使用JavaScript 1 第3章 基本概念 3 第二周 第4章 变量.作用域和内存 ...
- /var子目录
/var子目录 目录 描述 /var/log/message 日志信息,按周自动轮询 /var/spool/cron/root 定时器配置文件目录,默认按用户命名 /var/log/secure 记录 ...
- javascript 笔记(1)
document.forms[0].names.value == '' forms[0]表示文档的第一个 form 表单,names 表示这个表单元素名为 names 的表单的元素,此时表示的是获取此 ...
- Log4j 密码屏蔽
Log4j filter to mask Payment Card numbers (PCI DSS) According to PCI DSS (Payment Card Industry Data ...
- yii2源码学习笔记(十四)
Module类是模块和应用类的基类. yiisoft\yii2\base\Module.php <?php /** * @link http://www.yiiframework.com/ * ...
- js截取小数点后几位的写法
截取小数点后几位的方法有很多,下面为大家介绍下使用js是如何实现的 如果${showInfo.tt}的值为20,要要它除以10以后精确到小数点后2位,那么js代码中可作如下写法: 复制代码 代码如下 ...
- 本博客css style
#navList { min-height: 60px; } #navList li { height: 60px; } #navList a { margin: 0px 5px !important ...
- 将yyyyMMdd HH:mm:ss格式的时间转换成时间类型
DateTime.ParseExact(gmt_withdrawal, "yyyyMMddHHmmss", System.Globalization.CultureInfo.Cur ...