求助,怎么办啊!!!

迷宫最小步数-弱化版

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;
}
}
}
}

2 个赞
#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;
			}
		}
	}
}

帮忙格式化了一下

3 个赞

什么叫帮忙格式化一下

3 个赞
#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++;
        return ;
	}
	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;
			}
		}
	}
}

这样子是TLE80,我再改改看

2 个赞