样例没过求调,必关
  • 板块P1605 迷宫
  • 楼主Songshuai
  • 当前回复7
  • 已保存回复7
  • 发布时间2025/7/23 14:24
  • 上次更新2025/7/23 17:07:36
查看原帖
样例没过求调,必关
1748379
Songshuai楼主2025/7/23 14:24
#include<bits/stdc++.h>
using namespace std;
int used[10][10],zhang[10][10],dx[4]={0,0,1,-1},dy[4]={-1,1,0,0};
int n,m,t,sx,sy,fx,fy,tx,ty;
int ans;
void dfs(int x,int y){
	if(x==fx&&y==fy){
       	ans++;
        return ;
    }
	for(int i=0;i<4;i++){
		if(x+dx[i]>n||x+dx[i]<1){
			return ;
		}
		else if(y+dy[i]>m||y+dy[i]<1){
			return ;
		}
		else if(used[x+dx[i]][y+dy[i]]==1){
			return ;
		}
		else if(zhang[x+dx[i]][y+dy[i]]==1){
			return ;
		}
		used[x][y]=1;
		dfs(x+dx[i],y+dy[i]);
		used[x][y]=0;
	}
}	
int main(){
	cin>>n>>m>>t;
	cin>>sx>>sy>>fx>>fy;
	used[sx][sy]=1;
	for(int i=1;i<=t;i++){
		cin>>tx>>ty;
		zhang[tx][ty]=1;
	}
	dfs(sx,sy);
	cout<<ans;
	return 0;
}
2025/7/23 14:24
加载中...