社区讨论

萌新刚学dfs,求助站外题

灌水区参与者 3已保存回复 6

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
6 条
当前快照
1 份
快照标识符
@lo25bu00
此快照首次捕获于
2023/10/23 08:15
2 年前
此快照最后确认于
2023/11/03 08:32
2 年前
查看原帖
LATEX
寻宝
小华在玩一个走迷宫的游戏,他身处一个2维的迷宫,需要避开危险找到宝藏。
在游戏地图中,小华能够向上下左右移动,同时有一些位置存在未知的危险,小华必须严格绕开。当然,通往藏宝阁的入口不只有一个,小华只需要走到任意一个入口即可。
小华每移动一步需要1单位时间,而由于电脑屏幕一次只能显示一行地图,所以上下移动时,电脑 需要额外1单位时间加载地图。幸运的是,小华已经提前得到了地图,如果要尽可能快地找到宝藏,最少需要花多少时间呢?
数据范围
对于30%的数据,n × m ≤ 104
对于另外20%的数据,保证地图中只有一个E
对于100%的数据,1 ≤ n, m ≤ 2000。
 
CPP
输入数据:
第一行分别输入n,m

然后输入地图,"."代表空地,"#"代表未知危险,"S"代表起点,"E"代表终点。

输出为时间
CPP
#include <bits/stdc++.h>
using namespace std;
char mapp[2010][2010];
bool vis[2010][2010];
int n,m,starti,startj,cnt=0;
void dfs(int posi,int posj){
    //cout<<posi<<' '<<posj<<endl;
    cnt++;
    vis[posi][posj]=1;
    int dx[5]={0,0,1,0,-1};
    int dy[5]={0,-1,0,1,0};
    if(mapp[posi][posj]=='E'){
        cout<<cnt;
    }else if(mapp[posi][posj]=='#'){
        return;
    }
    for(int i=1;i<=4;i++){
        if(!vis[posi+dx[i]][posj+dy[i]]){
            dfs(posi+dx[i],posj+dy[i]);
        }
    }
}
int main(){
    cin>>n>>m;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            cin>>mapp[i][j];
            if(mapp[i][j]=='S'){
                starti=i;
                startj=j;
            }
        }
    }
    dfs(starti,startj);
    return 0;
}
		

回复

6 条回复,欢迎继续交流。

正在加载回复...