C++ 迷宫问题 题解

问题描述

设有一个 N×N(2≤N<10)方格的迷宫,入口和出口分别在左上角和右上角

迷宫格子中分别放0 和 1,0 表示可通,1 表示不能,入口和出口处肯定是00

迷宫走的规则如下所示:

从某点开始,有八个方向可走,前进方格中数字为 0 时表示可通过,为 1 时表示不可通过

找出所有从入口(左上角)到出口(右上角)的路径(不能重复),输出路径总数,如果无法到达,则输出 0

输入格式

第一行输入一个整数N

接下来N行N列,输出一个0/1矩阵

输入样例

复制代码
3
0 0 0
0 1 1
1 0 0

输出样例

复制代码
2

思路:

用DFS,注意回溯

AC代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int dir[][2]={0,1,0,-1,1,0,-1,0,-1,-1,-1,1,1,-1,1,1};
bool vis[15][15];
int mat[15][15],cnt=0,n;
void dfs(int r,int c)
{
    if(r==1&&c==n)
    {
        cnt++;
        return;
    }
    for(int i=0;i<8;i++)
    {
        int dr=r+dir[i][0],dc=c+dir[i][1];
        if(dr>=1&&dc>=1&&dr<=n&&dc<=n&&!mat[dr][dc]&&!vis[dr][dc])
        {
            vis[dr][dc]=true;
            dfs(dr,dc);
            vis[dr][dc]=false;
        }
    }
}
int main()
{
    cin >> n;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            cin >> mat[i][j];
        }
    }
    vis[1][1]=true;
    dfs(1,1);
    cout<<cnt;
    return 0;
}
相关推荐
源代码•宸4 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang
旖旎夜光5 小时前
多态(11)(下)
c++·学习
yongui478345 小时前
MATLAB的指纹识别系统实现
算法
高山上有一只小老虎5 小时前
翻之矩阵中的行
java·算法
yangpipi-5 小时前
《C++并发编程实战》 第4章 并发操作的同步
开发语言·c++
jghhh015 小时前
RINEX文件进行卫星导航解算
算法
Chance_to_win5 小时前
C++基础知识
c++
爱思德学术5 小时前
中国计算机学会(CCF)推荐学术会议-A(计算机科学理论):LICS 2026
算法·计算机理论·计算机逻辑
CVHub5 小时前
多模态图文训推一体化平台 X-AnyLabeling 3.0 版本正式发布!首次支持远程模型推理服务,并新增 Qwen3-VL 等多款主流模型及诸多功能特性,等
算法
有趣的我5 小时前
C++ 多态介绍
开发语言·c++