求助
查看原帖
求助
538578
yuankaihan123楼主2021/9/21 14:10
#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;
}
2021/9/21 14:10
加载中...