【洛谷千题详解】P1605 迷宫

目录

题目总览

题目描述

输入格式

输出格式

输入输出样例

思路分析

AC代码


题目总览

题目描述

给定一个 N×M 方格的迷宫,迷宫里有 T 处障碍,障碍处不可通过。

在迷宫中移动有上下左右四种方式,每次只能移动一个方格。数据保证起点上没有障碍。

给定起点坐标和终点坐标,每个方格最多经过一次,问有多少种从起点坐标到终点坐标的方案。

输入格式

第一行为三个正整数 N,M,T,分别表示迷宫的长宽和障碍总数。

第二行为四个正整数 SX,SY,FX,FY,SX,SY 代表起点坐标,FX,FY 代表终点坐标。

接下来 T 行,每行两个正整数,表示障碍点的坐标。

输出格式

输出从起点坐标到终点坐标的方案总数。

输入输出样例

Input 1:

cpp 复制代码
2 2 1
1 1 2 2
1 2

Output 1:

cpp 复制代码
1

思路分析

经典DFS模版题,实在做不出来就看我的DFS讲解吧。

注意以下几点:

1.记得回溯

2.读入数据的顺序别读入错误

3.只有四个方向,并非八个方向

AC代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
bool a[10][10];
bool vis[10][10]={0};
int n,m,t,sx,sy,fx,fy,ans=0,tx,ty;
int dx[4]={0,0,1,-1};
int dy[4]={-1,1,0,0};
void dfs(int x,int y)
{
	if(x==fx&&y==fy)
	{
		ans++;
		return;
	}
	vis[x][y]=true;
	for(int i=0;i<=3;i++)
	{
	    int nx=x+dx[i];
	    int ny=y+dy[i];
	   	if(!vis[nx][ny]&&a[nx][ny]&&x>=1&&y>=1&&x<=n&&y<=m)	
        {
	         dfs(nx,ny);	
	    }
	}
	vis[x][y]=false; 
}
int main()
{
	cin>>n>>m>>t>>sx>>sy>>fx>>fy;
	for(int i=1;i<=n;i++)
	{
	    for(int j=1;j<=m;j++)
	    {
	        a[i][j]=true;
	    }
	}
	for(int i=1;i<=t;i++)
	{
		cin>>tx>>ty;
		a[tx][ty]=false;
	}
	vis[sx][sy]=true;//起点为真
	dfs(sx,sy);
	cout<<ans<<endl;
	return 0;
}
相关推荐
DuHz16 分钟前
UWB 雷达综述精读:应用、标准、信号处理、数据集、芯片与未来方向——论文阅读
论文阅读·学习·算法·信息与通信·信号处理
diediedei23 分钟前
C++中的适配器模式变体
开发语言·c++·算法
Timmylyx051826 分钟前
Codeforces Round 1075 (Div. 2) 题解
算法·codeforces·比赛日记
hadage23335 分钟前
--- 力扣oj柱状图中最大的矩形 单调栈 ---
算法·leetcode·职场和发展
json{shen:"jing"}35 分钟前
18. 四数之和
数据结构·算法·leetcode
千逐-沐风35 分钟前
SMU-ACM2026冬训周报1st
算法
天赐学c语言36 分钟前
1.25 - 零钱兑换 && 理解右值以及move的作用
c++·算法·leecode
北冥湖畔的燕雀39 分钟前
C++智能指针:告别内存泄漏的利器
c++·算法
傻乐u兔42 分钟前
C语言进阶————数据在内存中的存储1
c语言·数据结构·算法
多米Domi0111 小时前
0x3f 第42天 复习 10:39-11:33
算法·leetcode