[bzoj 1001][Beijing2006]狼抓兔子 (最小割+对偶图+最短路)
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新加数据一组,可能会卡掉从前可以过的程序。
Solution
如果按最小割建模用dinic是可以过的,效率还不错。刚开始我用isap直接爆了空间,(TAT)
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int MAXN=;
typedef pair<int,int> pt;
inline int Rin(){
int x=,c=getchar(),f=;
for(;c<||c>;c=getchar())
if(c==)f=-;
for(;c>&&c<;c=getchar())
x=(x<<)+(x<<)+c-;
return x*f;
}
bool mark[MAXN];
vector<pt>h;
int n,m,ecnt,fst[MAXN],s,t,d[MAXN];
struct edge{
int v,w,nxt;
}e[MAXN<<];
inline void link(int x,int y,int w){
e[++ecnt].v=y;
e[ecnt].w=w;
e[ecnt].nxt=fst[x];
fst[x]=ecnt;
e[++ecnt].v=x;
e[ecnt].w=w;
e[ecnt].nxt=fst[y];
fst[y]=ecnt;
}
void dijkstra(){
memset(d,0x3f,sizeof(d));
pt tmp;
d[s]=tmp.first=;tmp.second=s;
h.push_back(tmp);
for(int k=;k<t;k++){
int now=h.front().second;pop_heap(h.begin(),h.end()),h.pop_back();
mark[now]=;
for(int j=fst[now];j;j=e[j].nxt)
if(d[e[j].v]>d[now]+e[j].w){
d[e[j].v]=d[now]+e[j].w;
if(!mark[e[j].v]){
tmp.first=-d[e[j].v];
tmp.second=e[j].v;
h.push_back(tmp);
push_heap(h.begin(),h.end());
}
}
}
}
int main(){
n=Rin(),m=Rin();
if(n==||m==){
if(n>m)
n^=m,m^=n,n^=m;
int ans=0x3f3f3f3f;
for(int i=;i<m;i++)
ans=min(ans,Rin());
printf("%d\n",ans);
return ;
}
t=(n-)*(m-)*+;
for(int j=;j<m;j++)
link(j,t,Rin());
for(int i=;i<n-;i++)
for(int j=;j<m;j++)
link((i<<)*(m-)+j,((i<<)-)*(m-)+j,Rin());
for(int j=;j<m;j++)
link(,((n<<)-)*(m-)+j,Rin());
for(int i=;i<n-;i++)
for(int j=;j<=m;j++){
if(j==)link(,(i<<)*(m-)+m,Rin());
else{
if(j==m)link((i<<|)*(m-),t,Rin());
else link((i<<)*(m-)+j-,(i<<)*(m-)+j+m-,Rin());
}
}
for(int i=;i<n-;i++)
for(int j=;j<m;j++)
link((i<<|)*(m-)+j,(i<<)*(m-)+j,Rin());
dijkstra();
printf("%d\n",d[t]);
return ;
}
[bzoj 1001][Beijing2006]狼抓兔子 (最小割+对偶图+最短路)的更多相关文章
- bzoj 1001 [BeiJing2006]狼抓兔子——最小割转最短路
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1001 #include<cstdio> #include<cstring& ...
- BZOJ 1001: [BeiJing2006]狼抓兔子 最小割
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓 ...
- 【bzoj1001】[BeiJing2006]狼抓兔子 最小割+对偶图+最短路
题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...
- BZOJ1001 [BeiJing2006]狼抓兔子 最小割 对偶图 最短路
原文链接http://www.cnblogs.com/zhouzhendong/p/8686871.html 题目传送门 - BZOJ1001 题意 长成上面那样的网格图求最小割. $n,m\leq ...
- BZOJ.1001.[BeiJing2006]狼抓兔子(最小割ISAP)
题目链接 为什么这题网络流这么快,海拔那题就那么慢.. //119968kb 544ms //路不是有向的,所以要建四条边..既然如此就直接将反向边的流量设为w了.(or MLE...) #inclu ...
- BZOJ1001: [BeiJing2006]狼抓兔子 [最小割 | 对偶图+spfa]
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 19528 Solved: 4818[Submit][ ...
- BZOJ 1001: [BeiJing2006]狼抓兔子(s-t平面图+最短路求最小割)
http://www.lydsy.com/JudgeOnline/problem.php?id=1001 题意: 思路:这道题目是最小割题目,但是吧你直接套用Dinic是会超时的. 这里有种很奇妙的做 ...
- BZOJ1001: [BeiJing2006]狼抓兔子 (最小割转最短路)
浅析最大最小定理在信息学竞赛中的应用---周东 ↑方法介绍 对于一个联通的平面图G(满足欧拉公式) 在s和t间新连一条边e; 然后建立一个原图的对偶图G*,G*中每一个点对应原图中每一个面,每一条边对 ...
- BZOJ 1001 [BeiJing2006] 狼抓兔子(平面图最大流)
题目大意 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的.而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...
随机推荐
- Pick two points at random from the interior of a unit square, what is the expected distance between them?
My solution is as folllowing. This integration is hard to solve. I googled it, and found the result ...
- 带KEY的SCP命令,老是要查,这次写在这里吧,
有些东东记不住,急要用时老是想不起,放在这里吧, scp -r -i /xxx/rsa.key -P port user@ip:/source/ /target/
- Keil的可重定位段
对于一个大的文件,为了便于管理,一个好的办法时把一个大文件分为若干个小文件,每个小文件包含一部分相关的功能,这样功能将显得很整洁,而且移植到其它工程的时候也很方便,把文件copy过去即可. 对于汇编, ...
- android 之 百度地图
简介 百度地图Android定位SDK为基于移动客户端开发LBS应用提供基础定位能力. 功能介绍 功能介绍: 地图展示:包括2D图.卫星图.3D图地图展示. 地图操作:提供控制平移.缩放.底图旋转.变 ...
- zabbix 启用分区表后需要关闭Housekeeper
<pre name="code" class="html">Zabbix Housekeeper changes: 使用分区表需要关闭zabbix的 ...
- cf442B Andrey and Problem
B. Andrey and Problem time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- requirejs-define jquery 快速初学实例(一)
原文地址:http://6yang.net/articles_view.php?id=1103 2011-10-18 13:12:01 by [6yang], 1029 visits, 收藏 | 返回 ...
- java算法之身份证号码验证
调用时直接 new IDCard().verify(身份证id);就可以了 实现代码如下: public class IDCard { private String _codeError; //wi ...
- jquery href属性和click事件冲突
a标签的定义如下: <a href="javascript:void(0);">test</a> jquery中的click事件: $("a&qu ...
- JMeter脚本参数化和断言设置( CSV Data Set Config )
用Badboy录制了Jmeter的脚本,用Jmeter打开后形成了原始的脚本.但是在实际应用中,为了增强脚本的多样性,就要使脚本参数化.这里我以登录为例,参数化用户账号与用户密码. 图1 :原始脚本 ...