广搜疑问求解,悬1~3关
查看原帖
广搜疑问求解,悬1~3关
1342002
__^浅笑.__楼主2024/10/2 22:47
  • 为什么这道题一定要开一个数组存下路径,然后输出?

  • 我普通的广搜为什么过不了啊

#include <bits/stdc++.h>
using namespace std;
//#define int long long

int n,m;
struct node{
	int x,y;
};
queue<node> q;

char mp[5005][5005];
bool vis[5005][5005];

int dx[4]={-1,1,0,0};
int dy[4]={0,0,-1,1};

bool inmp(int x,int y){
	return x>=1 && x<=n && y>=1 && y<=m && vis[x][y]==false && mp[x][y]!='*';
}

void bfs(int x,int y){
	q.push({x,y});
	vis[x][y]=true;
	while(!q.empty()){
		node t=q.front();
		q.pop();
		
		int cx=t.x;
		int cy=t.y;
		cout<<cx<<" "<<cy<<endl;
		
		for(int i=0;i<4;i++){
			int xx=cx+dx[i];
			int yy=cy+dy[i];
			
			if(inmp(xx,yy)==true){
				q.push({xx,yy});
				vis[xx][yy]=true;
			}
		}
	}
}

int main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cin>>mp[i][j];
		}
	}
	bfs(1,1);
	return 0;
}

一问一关,第一问能让我彻底理解的两关

2024/10/2 22:47
加载中...