题目背景
迷宫 【问题描述】
给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过。给定起点坐标和
终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案。在迷宫
中移动有上下左右四种方式,每次只能移动一个方格。数据保证起点上没有障碍。
输入样例 输出样例
【数据规模】
1≤N,M≤5
题目描述
输入输出格式
输入格式:
【输入】
第一行N、M和T,N为行,M为列,T为障碍总数。第二行起点坐标SX,SY,终点
坐标FX,FY。接下来T行,每行为障碍点的坐标。
输出格式:
【输出】
给定起点坐标和终点坐标,问每个方格最多经过1次,从起点坐标到终点坐标的方
案总数。
输入输出样例
输入样例#1:
2 2 1
1 1 2 2
1 2
输出样例#1:
迷宫 【问题描述】
给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过。给定起点坐标和
终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案。在迷宫
中移动有上下左右四种方式,每次只能移动一个方格。数据保证起点上没有障碍。
输入样例 输出样例
【数据规模】
1≤N,M≤5
题目描述
输入输出格式
输入格式:
【输入】
第一行N、M和T,N为行,M为列,T为障碍总数。第二行起点坐标SX,SY,终点
坐标FX,FY。接下来T行,每行为障碍点的坐标。
输出格式:
【输出】
给定起点坐标和终点坐标,问每个方格最多经过1次,从起点坐标到终点坐标的方
案总数。
输入输出样例
输入样例#1:
2 2 1
1 1 2 2
1 2
输出样例#1:
1
#include<stdio.h>
char arr[10][10];
int book[10][10];//0表示没标记
int t,n,m,sx,sy,fx,fy,tx,ty,ans = 0;
int x[4] = {-1,0,1,0};
int y[4] = {0,1,0,-1};
void dfs(int xx,int yy){
if(arr[xx][yy] == 'f'){
ans++;
return;
}
for(int i = 0;i < 4;i ++){
int kx = xx + x[i];
int ky = yy + y[i];
if(kx > 0 && kx <= n && ky > 0 && ky <= m &&
book[kx][ky] == 0 && arr[kx][ky] != '#'){arr[kx][ky] == '.'这是错误的,因为这样永远进入不了终点。
book[kx][ky] = 1;
dfs(kx,ky);
book[kx][ky] = 0;
}
}
}
int main(){
scanf("%d%d%d",&n,&m,&t);
for(int i = 1;i <= n;i ++){
for(int j = 1;j <= m;j ++){
arr[i][j] = '.';
}
}
scanf("%d%d%d%d",&sx,&sy,&fx,&fy);
arr[sx][sy] = 's';
arr[fx][fy] = 'f';
for(int i = 0;i < t;i ++){
scanf("%d%d",&tx,&ty);
arr[tx][ty] = '#';
}
book[sx][sy] = 1;
dfs(sx,sy);
printf("%d\n",ans);
return 0;
}