[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] 狼抓兔子(平面图最大流)
题目大意 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的.而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...
随机推荐
- 使用jcifs.smb.SmbFile读取Windows上共享目录的文件
protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws Servl ...
- Ubuntu 下安装使用文件比较合并图形工具Meld
Meld是一款跨平台的文件比较合并工具使用Python开发,具体内容参照官网:http://meldmerge.org/ 注意以下环境要求: Requirements Python 2.7 (Pyth ...
- [LeetCode 121] - 买入与卖出股票的最佳时机(Best Time to Buy and Sell Stock)
问题 假设你有一个数组,其中的第i个元素表示一只股票在第i天的价格. 如果只允许你完成一次交易(即买入并卖出股票一次),设计一个找出最大利润的算法. 初始思路 和122一样,基于买入与卖出股票的最佳时 ...
- LeetCode_Unique Paths II
Follow up for "Unique Paths": Now consider if some obstacles are added to the grids. How m ...
- PlayerPrefs类
该类用于本地持久化保存与读取数据工作原理是:以键值对的形势将数据保存在文件中.该类可以保存与读取3种基本的数据类型,它们是浮点型.整型和字符串型,涉及的方法如下.SetFloat():保存浮点类型Se ...
- 【转】深入理解Android的startservice和bindservice--不错
原文网址:http://www.cnblogs.com/yejiurui/p/3429451.html 一.首先,让我们确认下什么是service? service就是android系 ...
- [置顶] Android安全机制分析
Android系统是基于Linux内核开发的,因此,Android系统不仅保留和继承了Linux操作系统的安全机制,而且其系统架构的各个层次都有独特的安全特性[2] . 1. Linux内核层安全机制 ...
- AIX 常用命令和知识
BOOTLIST:#bootlist -m normal -o (查看bootlist)#bootlist -m normal (设置bootlist为空,谁要在我机器上执行我就要哭了)#boot ...
- zookeeper应用——集中配置管理系统的实现
http://blog.csdn.net/huangfengxiao/article/details/8844239
- bit、byte、位、字节、字符串等概念
原始文章:http://djt.qq.com/article/view/658 1.古代送信:马车,烽火,信鸽 2.1837年,世界第一条电报诞生, 美国科学家莫尔斯尝试用一些“点”和“划”来表示不同 ...