社区讨论

求助

P1605迷宫参与者 1已保存回复 1

讨论操作

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

当前回复
1 条
当前快照
1 份
快照标识符
@lobqoj7j
此快照首次捕获于
2023/10/30 01:22
2 年前
此快照最后确认于
2023/11/04 05:58
2 年前
查看原帖
CPP
#include <bits/stdc++.h>
using namespace std;
int m,n,qd1,qd2,zd1,zd2,t,mapp[100][100],x,y,ans;
void dfs(int x1,int x2,int y1,int y2)
{
	if(x1==zd1 && x2==zd2)
	{
		ans++;
		return ;
	}
	if(mapp[x1][x2]==-1)	return ;
	if(x1>m && x2>n)	return ;
	if(y1==x1+1)
	{
		dfs(x1-1,x2,y1,y2);
		dfs(x1,x2+1,y1,y2);
		dfs(x1,x2-1,y1,y2);
	}
	if(y1==x1-1)
	{
		dfs(x1+1,x2,y1,y2);
		dfs(x1,x2+1,y1,y2);
		dfs(x1,x2-1,y1,y2);
	}
	if(y2==x2+1)
	{
		dfs(x1+1,x2,y1,y2);
		dfs(x1-1,x2,y1,y2);
		dfs(x1,x2-1,y1,y2);
	}
	if(y2==x2-1)
	{
		dfs(x1+1,x2,y1,y2);
		dfs(x1-1,x2,y1,y2);
		dfs(x1,x2+1,y1,y2);
	}
	else
	{
		dfs(x1+1,x2,y1,y2);
		dfs(x1-1,x2,y1,y2);
		dfs(x1,x2+1,y1,y2);
		dfs(x1,x2-1,y1,y2);
	}
}
int main()
{
	cin>>n>>m>>t>>qd1>>qd2>>zd1>>zd2;
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)
			mapp[i][j]=1;
	for(int i=1;i<=t;i++)
	{
		cin>>x>>y;
		mapp[x][y]=-1;
	}
	dfs(qd1,qd2,qd1,qd2);
	cout<<ans;
	return 0;
}

回复

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

正在加载回复...