BZOJ2464: 中山市选[2009]小明的游戏

时间:2023-03-09 23:29:48
BZOJ2464: 中山市选[2009]小明的游戏

2464: 中山市选[2009]小明的游戏

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 280  Solved: 124
[Submit][Status]

Description


明最近喜欢玩一个游戏。给定一个n *
m的棋盘,上面有两种格子#和@。游戏的规则很简单:给定一个起始位置和一个目标位置,小明每一步能向上,下,左,右四个方向移动一格。如果移动到同一类
型的格子,则费用是0,否则费用是1。请编程计算从起始位置移动到目标位置的最小花费。

Input

    输入文件有多组数据。
    输入第一行包含两个整数n,m,分别表示棋盘的行数和列数。
    输入接下来的n行,每一行有m个格子(使用#或者@表示)。
    输入接下来一行有四个整数x1, y1, x2, y2,分别为起始位置和目标位置。
当输入n,m均为0时,表示输入结束。

Output

    对于每组数据,输出从起始位置到目标位置的最小花费。每一组数据独占一行。

Sample Input

2 2
@#
#@
0 0 1 1
2 2
@@
@#
0 1 1 0
0 0

Sample Output

2
0

HINT

对于100%的数据满足:1 < = n, m <= 500。

Source

题解:
对于这种题目我只能说呵呵。。。
裸最短路吧,连spfa都不卡。。。
代码:
 #include<cstdio>

 #include<cstdlib>

 #include<cmath>

 #include<cstring>

 #include<algorithm>

 #include<iostream>

 #include<vector>

 #include<map>

 #include<set>

 #include<queue>

 #include<string>

 #define inf 1000000000

 #define maxn 1000000+5

 #define maxm 1000000

 #define eps 1e-10

 #define ll long long

 #define pa pair<int,int>

 #define for0(i,n) for(int i=0;i<=(n);i++)

 #define for1(i,n) for(int i=1;i<=(n);i++)

 #define for2(i,x,y) for(int i=(x);i<=(y);i++)

 #define for3(i,x,y) for(int i=(x);i>=(y);i--)

 #define mod 1000000007
#define num(i,j) ((i-1)*m+j) using namespace std; inline 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 go,next,w;}e[*maxn]; int n,m,k,s,t,a[maxn],tot,d[maxn],head[maxn]; bool v[maxn];
queue<int>q;
char st[maxn];
const int dx[]={,,,-};
const int dy[]={,,-,}; void insert(int x,int y,int z) { e[++tot].go=y;e[tot].w=z;e[tot].next=head[x];head[x]=tot; } int spfa(int s,int t) { for(int i=;i<=n*m;++i)d[i]=inf; memset(v,,sizeof(v)); d[s]=;q.push(s); while(!q.empty()) { int x=q.front();q.pop();v[x]=; for(int i=head[x],y;i;i=e[i].next) if(d[x]+e[i].w<d[y=e[i].go]) { d[y]=d[x]+e[i].w; if(!v[y]){v[y]=;q.push(y);} } }
return d[t]; } int main() { freopen("input.txt","r",stdin); freopen("output.txt","w",stdout); while()
{
n=read(),m=read();
if(n*m==)break;
memset(head,,sizeof(head));tot=;
for1(i,n)
{
scanf("%s",st+);
for1(j,m)a[num(i,j)]=st[j]=='#'?:;
}
for1(i,n)
for1(j,m)
for0(k,)
{
int ii=i+dx[k],jj=j+dy[k];
if(ii<||ii>n||jj<||jj>m)continue;
insert(num(i,j),num(ii,jj),a[num(i,j)]!=a[num(ii,jj)]);
}
int x1=read()+,y1=read()+,x2=read()+,y2=read()+;
printf("%d\n",spfa(num(x1,y1),num(x2,y2)));
} return ; }