求助,只有50分
  • 板块P1605 迷宫
  • 楼主z1212
  • 当前回复4
  • 已保存回复4
  • 发布时间2021/1/28 17:45
  • 上次更新2023/11/5 04:13:53
查看原帖
求助,只有50分
61737
z1212楼主2021/1/28 17:45
#include<iostream>
using namespace std;
int wk[4][2]= {{-1,0},{0,1},{1,0},{0,-1}};
int n,m,t,sx,sy,fx,fy,dx,dy,s,nx,ny,po;
bool b[10][10];
void f(int x,int y) {
     if(x==fx&&y==fy)
     {
     	s++;
     	return;
	 }
	 for(int i=0;i<=3;i++)
	 {
	 	nx=x+wk[i][0];
	 	ny=y+wk[i][1];
	 	if(nx>=1&&nx<=n&&ny>=1&&ny<=m&&b[nx][ny]==0)
	 	{
	 		b[nx][ny]=1;
	 		f(nx,ny);
	 		b[nx][ny]=0;
		 }
	 }
	 return;
}
int main() {
	cin>>n>>m>>t;
	cin>>sx>>sy>>fx>>fy;
	for(int i=1; i<=t; i++) {
		cin>>nx>>ny;
		b[nx][ny]=1;
	}
	b[sx][sy]=1;
	f(sx,sy);
	cout<<s;
	return 0;
}
2021/1/28 17:45
加载中...