迷宫最小步数-弱化版
Problem ID: 9337
Contest ID: 5346
选做题
Wrong Answer
70 分
迷宫最小步数(弱化版)
时间:1s 空间:64mb
题目描述:
给定一个大小为n * m的迷宫,求出从起点到终点的最小步数 ,只能上下左右四个方向走(若起点无法到达终点则输出-1)【*代表通道、#代表墙壁】
输入格式:
第一行,两个整数n,m
第2~n+1行,每行输入一个长度为m的字符串(由*和#组成)
第n+2行,4个整数a,b,c,d 代表起点(a,b),终点(c,d)
输出格式:
一个整数,代表从起点到终点的最小步数。
输入样例
5 6
*****#
*##*##
*#**##
*#*#*#
******
1 1 5 3
输出样例
6
约定:
0<n,m<50
我的代码:
#include<bits/stdc++.h>
using namespace std;
int n,m,sum=0,dx[4]={-1,0,1,0},dy[4]={0,-1,0,1},p=25000;
char s[100][100];
bool h[100][100] = {false};
void fo(int x,int y,int a,int b,int l);
int main(){
int a,b,c,d;
cin>>n>>m;
for(int i = 1; i<=n; i++){
for(int j = 1; j<=m; j++){
cin>>s[i][j];
}
}
cin>>a>>b>>c>>d;
h[1][1] = true;
fo(a,b,c,d,0);
if(sum>=1){
cout<<p;
}else{
cout<<-1;
}
return 0;
}
void fo(int x,int y,int a,int b,int l){
if(x == a && y == b){
if(l<p){
p = l;
}
sum++;
}else{
for(int i = 0; i<4; i++){
int s1=x+dx[i],s2=y+dy[i];
if(s1<=n && s1>0 && s2>0 && s2<=m && s[s1][s2] != ‘#’ && h[s1][s2] == false){
h[s1][s2] = true;
fo(s1,s2,a,b,l+1);
h[s1][s2] = false;
}
}
}
}