Bzoj1001 [BeiJing2006]狼抓兔子
Time Limit: 15 Sec Memory Limit: 162 MB
Submit: 19759 Solved: 4883
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
显然是一个最小割问题。
然而数据范围太大了,最小割妥妥会TLE
考虑把最小割转化为最短路:一个平面图的最小割问题可以转化成它的对偶图的最短路问题。
平面图中的每个面对应对偶图中的一个点,在这个问题中,可以将每个小三角形当成一个点,其左上角顶点是入点,右下角顶点是出点(网络流拆点思想)。
建边求最短路即可。
顺便测试了两种dijkstra,没注释掉的这个版本比注释掉的版本慢了约200ms,似乎大常数的inq判断比大常数的优先队列更耗时间?
- /*by SilverN*/
- #include<algorithm>
- #include<iostream>
- #include<cstring>
- #include<cstdio>
- #include<cmath>
- #include<vector>
- #include<queue>
- using namespace std;
- const int mxn=;
- int read(){
- int x=,f=;char ch=getchar();
- while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
- while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
- return x*f;
- }
- struct edge{int v,nxt,w;}e[mxn*];
- int hd[mxn],mct=;
- inline void add_edge(int u,int v,int w){
- e[++mct].v=v;e[mct].nxt=hd[u];e[mct].w=w;hd[u]=mct;return;
- }
- inline void insert(int u,int v,int w){
- add_edge(u,v,w);add_edge(v,u,w);return;
- }
- int n,m,S,T;
- inline int id(int x,int y,int k){return ((x-)*(m-)+y)*-(k^);}
- //inline int id(int x,int y,int k){return (x-1)*(m-1)*2+y*2-(k^1);}
- /*
- struct dst{int u,dis;};
- struct cmp{bool operator ()(const dst a,const dst b){return a.dis>b.dis;}};
- priority_queue<dst,vector<dst>,cmp>q;
- int dis[mxn];
- void dij(){
- memset(dis,0x3f,sizeof dis);
- while(!q.empty())q.pop();
- q.push((dst){S,0});
- dis[S]=0;
- while(!q.empty()){
- dst now=q.top();q.pop();
- int u=now.u;if(dis[u]<now.dis)continue;
- for(int i=hd[u];i;i=e[i].nxt){
- int v=e[i].v;
- if(dis[v]>dis[u]+e[i].w){
- dis[v]=dis[u]+e[i].w;
- q.push((dst){v,dis[v]});
- }
- }
- }
- return;
- }
- */
- int dis[mxn];
- struct cmp{bool operator ()(const int a,const int b){return dis[a]>dis[b];}};
- priority_queue<int,vector<int>,cmp>q;
- bool inq[mxn];
- void dij(){
- memset(dis,0x3f,sizeof dis);
- while(!q.empty())q.pop();
- q.push(S);
- dis[S]=;inq[S]=;
- while(!q.empty()){
- int u=q.top();q.pop();inq[u]=;
- for(int i=hd[u];i;i=e[i].nxt){
- int v=e[i].v;
- if(dis[v]>dis[u]+e[i].w){
- dis[v]=dis[u]+e[i].w;
- if(!inq[v]){
- inq[v]=;
- q.push(v);
- }
- }
- }
- }
- return;
- }
- int main(){
- int i,j,w;
- n=read();m=read();
- S=(n-)*(m-)*+;T=S+;
- for(i=;i<=n;i++){
- for(j=;j<m;j++){
- w=read();
- if(i==)insert(S,id(i,j,),w);
- else if(i==n)insert(id(i-,j,),T,w);
- else insert(id(i,j,),id(i-,j,),w);
- }
- }
- for(i=;i<n;i++){
- for(j=;j<=m;j++){
- w=read();
- if(j==)insert(T,id(i,j,),w);
- else if(j==m)insert(id(i,j-,),S,w);
- else insert(id(i,j-,),id(i,j,),w);
- }
- }
- for(i=;i<n;i++)
- for(j=;j<m;j++){
- w=read();
- insert(id(i,j,),id(i,j,),w);
- }
- dij();
- printf("%d\n",dis[T]);
- return ;
- }
Bzoj1001 [BeiJing2006]狼抓兔子的更多相关文章
- BZOJ1001 BeiJing2006 狼抓兔子 【网络流-最小割】*
BZOJ1001 BeiJing2006 狼抓兔子 Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的,而且现在的兔子还比较 ...
- [BZOJ1001][BeiJing2006]狼抓兔子(最小割转最短路|平面图转对偶图)
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 31805 Solved: 8494[Submit][ ...
- BZOJ1001: [BeiJing2006]狼抓兔子 [最小割 | 对偶图+spfa]
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 19528 Solved: 4818[Submit][ ...
- BZOJ1001: [BeiJing2006]狼抓兔子【最短路+对偶图】
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1001 1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Se ...
- bzoj1001: [BeiJing2006]狼抓兔子 -- 最小割
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MB Description 现在小朋友们最喜欢的"喜羊羊与灰太狼 ...
- bzoj1001: [BeiJing2006]狼抓兔子(初识是你最小割)
1001: [BeiJing2006]狼抓兔子 题目:传送门 题解: 听说这题当初是大难题...可惜当年没有网络流hahahha 现在用网络流的思想就很容易解决了嘛 给什么连什么,注意是双向边,然后跑 ...
- BZOJ1001: [BeiJing2006]狼抓兔子(优化的dinic或转化对偶图求最短路)
1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 30078 Solved: 7908[Submit][ ...
- [bzoj1001][BeiJing2006]狼抓兔子_网络流_最小割转对偶图
狼抓兔子 bzoj-1001 BeiJing2006 Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还 ...
- BZOJ1001[BeiJing2006]狼抓兔子最小割網絡流
Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一 ...
随机推荐
- 嵌入支付宝SDK,出现“LaunchServices: ERROR: There is no registered handler for URL scheme alipay”错误
应用项目中嵌入支付宝SDK,在模拟器运行app后,会出现“LaunchServices: ERROR: There is no registered handler for URL scheme al ...
- wcf的诡异问题
最近在做工作流设计器用的silverlight 使用wcf服务. 过程中遇到了两个奇怪的问题. 1. 出现整型参数无法传递到服务器的情况 2.出现反序列化失败的情况. 经过仔细排查发现 每个属性都有一 ...
- node基础06:回调函数
1.Node异步编程 Node.js 异步编程的直接体现就是回调. 异步编程依托于回调来实现,但不能说使用了回调后程序就异步化了. 回调函数在完成任务后就会被调用,Node 使用了大量的回调函数,No ...
- hadoop 2.6伪分布安装
hadoop 2.6的“伪”分式安装与“全”分式安装相比,大部分操作是相同的,主要区别在于不用配置slaves文件,而且其它xxx-core.xml里的参数很多也可以省略,下面是几个关键的配置: (安 ...
- win8.1环境下安装arduino驱动问题解决方案
1. Windows 键+ R, 输入 shutdown.exe /r /o /f /t 00 2.此时电脑会自动重启,进入一下画面,选择Troubleshoot (转载请注明原处:http://ww ...
- 纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!
前言 FineUI控件库发展至今已经有 5 个年头,目前论坛注册的QQ会员 5000 多人,捐赠用户 500 多人(捐赠用户转化率达到10%以上,在国内开源领域相信这是一个梦幻数字!也足以证明Fine ...
- opencv8-GPU之相似性计算
Opencv支持GPU计算,并且包含成一个gpu类用来方便调用,所以不需要去加上什么__global__什么的很方便,不过同时这个类还是有不足的,待opencv小组的更新和完善. 这里先介绍在之前的& ...
- 后记:Cookie安全大辩论总结
前天,我发布在博客园上的某知名电商网站的Cookie漏洞引发园友们的热议,学到了很多知识,现在整理一下其中比较激烈的技术讨论.谁对谁错每个人自己心中都有一把称,很多时候都是我无法说服你,你也无法说服我 ...
- 突破自我,开源NetWorkSocket通讯组件
前言 在<化茧成蝶,开源NetWorkSocket通讯组件>发表之后,收到大家很多个star,在此感谢!更可贵的是,一些网友提出了许多好建议,经过一些时间的思考,决定将NetworkSoc ...
- .net 估计要死在你手里了
最近不太爽,想换工作,上这些知名的招聘网站,一搜 .net 心凉了一截,很少有大公司用.net,工资也不是很高. 不用我多说什么,想必很多人应该有类似经历,只是打了牙往肚子里咽. 来两副图: 最近用滴 ...