电子老鼠走迷宫(广搜)WA
1042.电子老鼠闯迷宫时限:1000ms 内存限制:10000K 总时限:3000ms
描述
有一只电子老鼠被困在如下图所示的迷宫中。这是一个12*12单元的正方形迷宫,黑色部分表示建筑物,白色部分是路。电子老鼠可以在路上向上、下、左、右行走,每一步走一个格子。现给定一个起点S和一个终点T,求出电子老鼠最少要几步从起点走到终点。
输入
本题包含一个测例。在测例的第一行有四个由空格分隔的整数,分别表示起点的坐标S(x.y)和终点的坐标T(x,y)。从第二行开始的12行中,每行有12个字符,描述迷宫的情况,其中'X'表示建筑物,'.'表示路.
输出
输出一个整数,即电子老鼠走出迷宫至少需要的步数。
输入样例
2 9 11 8
XXXXXXXXXXXX
X......X.XXX
X.X.XX.....X
X.X.XX.XXX.X
X.X.....X..X
X.XXXXXXXXXX
X...X.X....X
X.XXX...XXXX
X.....X....X
XXX.XXXX.X.X
XXXXXXX..XXX
XXXXXXXXXXXX
输出样例
28
程序代码:#include <stdio.h>
#include <string.h>
struct note
{
int x;//横坐标
int y;//纵坐标
int s;//步数
};
int main()
{
struct note que[145];
int book[13][13] = {0};
char a[13][13];
int next[4][2]={{0,1},{1,0},{0,-1},{-1,0}};
int head,tail;
int i,k,n=12,m=12,startx,starty,p,q,tx,ty,flag;
scanf("%d %d %d %d",&startx,&starty,&p,&q);
getchar();
for(i=1;i<=n;i++)
gets(a[i]);
//队列初始化
head = 1;
tail = 1;
//往队列插入迷宫入口坐标
que[tail].x = startx;
que[tail].y = starty;
que[tail].s = 0;
tail++;
book[startx][starty] = 1;
flag = 0;//用来标记是否到达目标点,0表示暂未,1表示到达
//当队列不为空时循环
while(head<tail)
{
//枚举四个方向
for (k=0;k<=3;k++)
{
//计算下一个点的坐标
tx = que[head].x+next[k][0];
ty = que[head].y+next[k][1];
//判断是否越界
if (tx<1||tx>n||ty<1||ty>m)
{
continue;
}
if(a[tx][ty]=='.'&&book[tx][ty]==0)
{
book[tx][ty] = 1;
que[tail].x = tx;
que[tail].y = ty;
que[tail].s = que[head].s+1;
tail++;
}
if (tx==p&&ty==q)
{
flag = 1;
break;
}
}
if (flag == 1)
{
break;
}
head++;
}
printf("%d\n",que[tail-1].s);
return 0;
}
/*
6 6 11 11
XXXXXXXXXXXX
X..........X
X.XXXXXXXX.X
X.X......X.X
X.X.XXXX.X.X
X.X.X..X.X.X
X.X.XX.X.X.X
X.X.XX.X.X.X
X.X....X.X.X
X.XXXXXX.X.X
X........X.X
XXXXXXXXXXXX
58
*/
/*
11 11 4 4
XXXXXXXXXXXX
X........XXX
X.XXXXXX...X
X...XX.XXX.X
X.XXXX.....X
X.X..X..X.XX
X.X....XX.XX
X...XX..X.XX
X..XXXX.X.XX
X.XXXX.....X
X..X...XXX.X
XXXXXXXXXXXX
20
*/[code][/code]最后两个测例,WA!!!











