★★★   输入文件:bjrabbit.in   输出文件:bjrabbit.out   简单对比
时间限制:1 s   内存限制:162 MB

Description   Source: Beijing2006 [BJOI2006]

八中OJ上本题链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001

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

左上角点为(1,1),右下角点为(N,M)(上图中N=4,M=5).有以下三种类型的道路 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只狼,才能完全封锁这条道路,你需要帮助狼王安排一个伏击方案,使得在将兔子一网打尽的前提下,参与的狼的数量要最小。因为狼还要去找喜羊羊麻烦.

Input

第一行为N,M.表示网格的大小,N,M均小于等于1000.接下来分三部分 第一部分共N行,每行M-1个数,表示横向道路的权值. 第二部分共N-1行,每行M个数,表示纵向道路的权值. 第三部分共N-1行,每行M-1个数,表示斜向道路的权值. 输入文件保证不超过10M

Output

输出一个整数,表示参与伏击的狼的最小数量.

Sample Input

3 4
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

14
 
 
如果你想到了一个定理:
最大流==最小割,
然后聪明的想到了Dinic跑最大流
那么恭喜你,
被坑了,。。,
因为这道题的数据范围比较大
Dinic肯定跑步过去,
所以考虑用对偶图跑最短路,
至于为什么,,,我也不太懂,,
特别是代码。。
 
 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<queue>
#define inf 0x7fffffff
using namespace std;
const int maxn=+;
const int M = maxn*+; int n,m,nn,mm;
int from,to;
struct Edge
{
int v,flow;
int next;
}edge[M];
int head[maxn],edgenum; void add(int u,int v,int flow)
{
edge[edgenum].v=v ;edge[edgenum].flow=flow ;
edge[edgenum].next=head[u] ;head[u]=edgenum++ ; edge[edgenum].v=u ;edge[edgenum].flow=flow ;
edge[edgenum].next=head[v] ;head[v]=edgenum++ ;
} struct node
{
int v,w;
friend bool operator < (node a,node b)
{
return a.w > b.w;
}
}cur,tail;
int d[maxn],vis[maxn];
void Dijkstra(int from,int to)
{
for (int i= ;i<maxn ;i++) d[i]=inf;
memset(vis,,sizeof(vis));
d[from]=;
priority_queue<node> Q;
cur.v=from ;cur.w= ;
Q.push(cur);
while (!Q.empty())
{
cur=Q.top() ;Q.pop() ;
int x=cur.v;
if (vis[x]) continue;
vis[x]=;
for (int i=head[x] ;i!=- ;i=edge[i].next)
{
if (d[edge[i].v ]>d[x]+edge[i].flow)
{
d[edge[i].v ]=d[x]+edge[i].flow;
tail.v=edge[i].v;
tail.w=d[edge[i].v ];
Q.push(tail);
}
}
}
printf("%d\n",d[to]);
} int main()
{
while (scanf("%d%d",&n,&m)!=EOF)
{
memset(head,-,sizeof(head));
edgenum=;
from=;
to=*(n-)*(m-)+;
int x,y,cost;
for (int i= ;i<=n ;i++)
{
for (int j= ;j<m ;j++)
{
scanf("%d",&cost);
x= i== ? from : (*(i-)-)*(m-)+j;
y= i==n ? to : (*(i-))*(m-)+j;
add(x,y,cost);
}
}
for (int i= ;i<n ;i++)
{
for (int j= ;j<=m ;j++)
{
scanf("%d",&cost);
x= j== ? to : (*(i-))*(m-)+j-;
y= j==m ? from : (*(i-))*(m-)+j-+m;
add(x,y,cost);
}
}
for (int i= ;i<n ;i++)
{
for (int j= ;j<m ;j++)
{
scanf("%d",&cost);
x=(*(i-))*(m-)+j;
y=(*(i-)+)*(m-)+j;
add(x,y,cost);
}
}
Dijkstra(from,to);
}
return ;
}

下面是自己写的蜜汁WA、、

 
 #include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<queue>
#include<algorithm>
using namespace std;
const int MAXN=;
const int MAXM=;
const int maxn=0x7fffffff;
inline void read(int &n)
{
char c='+';int x=;bool flag=;
while(c<''||c>''){c=getchar();if(c=='-')flag=;}
while(c>=''&&c<=''){x=x*+(c-);c=getchar();}
flag==?n=-x:n=x;
}
struct node
{
int u,v,f,nxt;
}edge[MAXM];
int head[MAXN];
int num=;
int n,m;
int dis[MAXN];
bool vis[MAXN];
inline void add_edge(int x,int y,int z)
{
edge[num].u=x;
edge[num].v=y;
edge[num].f=z;
edge[num].nxt=head[x];
head[x]=num++;
}
inline void SPFA(int s,int t)
{
for(int i=;i<t;i++)
dis[i]=maxn;
dis[s]=;
vis[s]=;
queue<int>q;
q.push(s);
while(q.size()!=)
{
int p=q.front();
q.pop();
vis[p]=;
for(int i=head[p];i!=-;i=edge[i].nxt)
{
if(dis[edge[i].v]>dis[edge[i].u]+edge[i].f)
{
dis[edge[i].v]=dis[edge[i].u]+edge[i].f;
if(vis[edge[i].v]==)
{
vis[edge[i].v]=;
q.push(edge[i].v);
}
}
}
}
printf("%d",dis[t]);
}
int main()
{
//freopen("bjrabbit.in","r",stdin);
//freopen("bjrabbit.out","w",stdout);
read(n);read(m);
memset(head,-,sizeof(head));
int from=;
int to=(*(n-)*(m-))+;
int spend,x,y;
for(int i=;i<=n;i++)
for(int j=;j<m;j++)
{
read(spend);
x= i==? from: (*(i-)-)*(m-)+j;
y= i==n? to : (*(i-))*(m-)+j;
// printf("%d %d %d \n",x,y,spend);
add_edge(x,y,spend);
add_edge(y,x,spend);
}
for(int i=;i<n;i++)
for(int j=;j<=m;j++)
{
read(spend);
x= j==?to:(*(i-))*(m-)+j-;
y= j==m?from:(*(i-))*(m-)+j-+m;
//printf("%d %d %d \n",x,y,spend);
add_edge(x,y,spend);
add_edge(y,x,spend);
}
for(int i=;i<n;i++)
for(int j=;j<m;j++)
{
read(spend);
x=(*(i-))*(m-)+j;
y=(*(i-)+)*(m-)+j;
//printf("%d %d %d \n",x,y,spend);
add_edge(x,y,spend);
add_edge(y,x,spend);
}
SPFA(from,to);
return ;
}

752. [BJOI2006] 狼抓兔子的更多相关文章

  1. P4001 [BJOI2006]狼抓兔子(对偶图)

    P4001 [BJOI2006]狼抓兔子 最短路+对偶图 看这题最容易想到的就是网络流.Dinic可以过,据说还跑得比正解快. 如果不写网络流,那么需要知道2个前置知识:平面图和对偶图(右转baidu ...

  2. BJOI2006狼抓兔子

    1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 9967  Solved: 2267[Submit][S ...

  3. [BJOI2006]狼抓兔子

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

  4. 1001. [BJOI2006]狼抓兔子【最小割】

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

  5. BZOJ1001 BJOI2006 狼抓兔子

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

  6. [BJOI2006]狼抓兔子(网络流)

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

  7. BZOJ1001 洛谷4001 [BJOI2006]狼抓兔子 题解

    题目 这个题目有多种解法,这个题也是一个比较经典的题了,正是因为他的多样的做法,这个题主要难在建图和优化,因为这是一个网格图,所以spfa肯定过不去,所以用最短路解法的话,只能用dij,而网络流也是要 ...

  8. BZOJ1001 BJOI2006狼抓兔子(最小割+最短路)

    显然答案就是最小割.直接跑dinic也能过,不过显得不太靠谱. 考虑更正确的做法.作为一个平面图,如果要把他割成两半,那么显然可以用一条曲线覆盖且仅覆盖所有割边.于是我们把空白区域看成点,隔开他们的边 ...

  9. P4001 [BJOI2006]狼抓兔子

    传送门 思路: 不少题解都是用网络流来做最小割(网络流是什么),但对于一个不会网络流的蒟蒻来做这题相当困难. 听机房daolao说可以重构图做最短路.然后就baidu将平面图转换成一个对偶图,因为网络 ...

随机推荐

  1. linux的chmod,chown命令 详解

    指令名称 : chmod 使用权限 : 所有使用者 使用方式 : chmod [-cfvR] [--help] [--version] mode file... 说明 : Linux/Unix 的档案 ...

  2. vue中使用UEditor编辑器 -- 2

    1:下载ueditor下来,放在vue项目中的static文件夹下   2:创建ueditor编辑界面 3:椰~~~~~此时已经可以使用了 但是你会发现   (黑人脸)what the fuck??? ...

  3. iOS开发 小知识点

    1/ iOS汉字百分号互相转换. //汉字 NSString * name = @"时间终于将我对你的爱消耗殆尽"; //汉字转为百分比 NSString * encodeStri ...

  4. 3Ds Max实例教程-制作女战士全过程

    3Ds Max制作“女战神” 作者:Diego Rodríguez 使用软件:3Ds Max,Photoshop 3Ds Max下载:http://wm.makeding.com/iclk/?zone ...

  5. 如何使用 GNOME Shell 扩展

    如何使用 GNOME Shell 扩展 作者: Abhishek Prakash 译者: LCTT MjSeven | 2018-03-15 10:53   评论: 1 简介:这是一份详细指南,我将会 ...

  6. servletconfig和servletcontext学习

    servletconfig java.lang.String getInitParameter(java.lang.String name)  //根据参数名获取参数值 java.util.Enume ...

  7. maven的pom.xml配置json依赖

    <dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</art ...

  8. sklearn学习9----LDA(discriminat_analysis)

    1.导入模块 http://scikit-learn.org/stable/modules/generated/sklearn.discriminant_analysis.LinearDiscrimi ...

  9. faker smtp server

    import os import asyncio import logging import base64 from email import message_from_bytes from emai ...

  10. CSS Grid(CSS网格)

    Grid被设计来做一些Flexbox不能做的事情,所以不是被设计来取代Flexbox的. flexbox 一维的 Grid 二维的 总结:  Grid Items作用在Grid Container的直 ...