BFS和DFS入门题 洛谷B3625

题目链接:

题目描述:

解题思路:

用一个数组记录能到的点,用DFS或者用BFS从起点开始遍历,将所有的能到的点对应的数组置为1,写代码的时候注意边界处理。

BFS代码

首先将起点入队列,然后通过起点扩展其他节点,标记所有能到的节点。最后通过vis[n][m]就能得出答案了。用BFS还可以求最短路径,最小消费。因为BFS第一次到达的一定是最短的。

#include<bits/stdc++.h>
using namespace std;
int n,m;
char arr[105][105];
int vis[105][105];
int fx[4][2]={
          
   {
          
   1,0},{
          
   -1,0},{
          
   0,1},{
          
   0,-1}};//定义上下左右四个方向
struct node{
          
   
    int x,y;
};
queue<node>q;
int main(){
          
   
  	cin>>n>>m;
  	for(int i=1;i<=n;i++){
          
   
  		for(int j=1;j<=m;j++){
          
   
  			cin>>arr[i][j];
		}
	}
	q.push({
          
   1,1});//将起点加入队列
	vis[1][1]=1;//标记起点已经访问过,防止往回走
	while(q.size()){
          
   
        node p;
        p=q.front();//取队头
        q.pop();//弹出队头
        for(int i=0;i<4;i++){
          
   
            int x,y;
            x=p.x+fx[i][0];
            y=p.y+fx[i][1];
            if(x>0&&x<=n&&y>0&&y<=m&&vis[x][y]==0&&arr[x][y]!=#){
          
   
                q.push({
          
   x,y});//符合条件的入队列
                vis[x][y]=1;//标记访问过
            }
        }
	}
	if(vis[n][m]){
          
   
        cout<<"Yes" ;
	}else{
          
   
        cout<<"No";
	}
	return 0;
}

DFS代码

思路同BFS差不多,拿起点去扩展,直到把所有能到的节点遍历完。

#include<bits/stdc++.h>
using namespace std;
int n,m;
char arr[105][105];
int vis[105][105];
int fx[4][2]={
          
   {
          
   1,0},{
          
   -1,0},{
          
   0,1},{
          
   0,-1}};
void dfs(int x,int y){
          
   
    vis[x][y]=1;
    for(int i=0;i<4;i++){
          
   
        int x1,y1;
        x1=x+fx[i][0];
        y1=y+fx[i][1];
        if(x1>0&&x1<=n&&y1>0&&y1<=m&&vis[x1][y1]==0&&arr[x1][y1]!=#)
            dfs(x1,y1);
    }
}
int main(){
          
   
  	cin>>n>>m;
  	for(int i=1;i<=n;i++){
          
   
  		for(int j=1;j<=m;j++){
          
   
  			cin>>arr[i][j];
		}
	}
	dfs(1,1);
	if(vis[n][m]){
          
   
        cout<<"Yes" ;
	}else{
          
   
        cout<<"No";
	}
	return 0;
}
经验分享 程序员 微信小程序 职场和发展