Help
  • 板块P1605 迷宫
  • 楼主404Not_Found
  • 当前回复1
  • 已保存回复1
  • 发布时间2021/1/5 13:22
  • 上次更新2023/11/5 05:07:35
查看原帖
Help
280473
404Not_Found楼主2021/1/5 13:22
#include<iostream>
using namespace std;
int count;
int n,m,t,sx,sy,fx,fy;
bool could[6][6];
bool used[6][6];
int dx[]={-1,1,0,0};
int dy[]={0,0,-1,1};
void init()
{
	cin>>n>>m>>t>>sx>>sy>>fx>>fy;
	used[sx][sy]=true;
	for(int i=1;i<=t;i++)
	{
		int x,y;
		cin>>x>>y;
		could[x][y]=true;
	}
}
void dfs(int x,int y)
{
	if(x==fx && y==fy)
	{
		count++;
		return;
	}
	for(int i=0;i<=3;i++)
	{
		int xx=dx[i],yy=dx[y];
		used[x][y]=true;
		if(!used[xx][yy] && !could[xx][yy])
			dfs(xx,yy);
		used[x][y]=false;
	}
}
int main()
{
	init();
	dfs(sx,sy);
	cout<<count<<endl;
	return 0;
}
2021/1/5 13:22
加载中...