社区讨论

DFS--70--求助

P1605迷宫参与者 3已保存回复 4

讨论操作

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

当前回复
4 条
当前快照
1 份
快照标识符
@lo32scnk
此快照首次捕获于
2023/10/23 23:51
2 年前
此快照最后确认于
2023/10/23 23:51
2 年前
查看原帖
CPP
#include <bits/stdc++.h>
using namespace std;
const int N=20;
bool st[N][N];
int n,m,T;
int sx,sy,fx,fy;
#define x first
#define y second
typedef pair<int,int> PII;
int dx[4]={-1,0,1,0},dy[4]={0,1,0,-1};
PII tb[N];
int ans;
int num;
void dfs(int x,int y){
	if(x==fx&&y==fy){
		ans++;
		return;
	}
	for(int i=0;i<4;i++){
		int nx=x+dx[i],ny=y+dy[i];//遍历四个方向 
		if(!st[nx][ny]&&nx>=1&&nx<=n&&ny>=1&&ny<=m){//没有走过并且在迷宫里 
			bool flag=true;
			for(int j=0;j<T;j++){
				if(nx==tb[j].x&&ny==tb[j].y){
					flag=false;
					break;
				}
			}
			if(flag){//不是障碍 
				st[nx][ny]=true;
				dfs(nx,ny);
				st[nx][ny]=false;
			}
		}
	}
}
int main()
{
	cin>>n>>m>>T;
	cin>>sx>>sy>>fx>>fy;
	for(int i=0;i<T;i++) cin>>tb[i].x>>tb[i].y;
	dfs(sx,sy);
	cout<<ans<<endl;
	return 0;
}

回复

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

正在加载回复...