码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C++ 深度优先搜索(DFS) 讲解


    目录
    • 1 DFS初步概念
    • 2 DFS例题-迷宫游戏
      • 2.1 题目描述
      • 2.2 输入输出格式
      • 2.3 输入输出样例
        • 2.3.1 输入#1
        • 2.3.2 输出#1
        • 2.3.3 输入#2
        • 2.3.4 输出#2
      • 2.4 解题思路
      • 2.5 代码

    1 DFS初步概念

    DFS是一种深度搜索算法,它的特点是"不撞南墙不回头",运用递归对不同方向的结果进行搜索。

    2 DFS例题-迷宫游戏

    2.1 题目描述

    这是一个迷宫游戏,有一个n×n的矩阵,矩阵内只能有#或.这两种字符,如果是#则是墙,如果是.则是可以走的路。起点是左上角,终点是右下角,每次只能往上、下、左、右四个方向走。
    请你写一个程序,判断这个迷宫是否可以从起点走到终点。

    2.2 输入输出格式

    第1行一个整数n,代表矩阵大小为n×n。
    第2~n+1行输入n×n的迷宫矩阵。
    输出此迷宫是否能从起点走到终点,可以输出yes,不可以输出no。

    2.3 输入输出样例

    2.3.1 输入#1

    5
    ..##.
    #..##
    ..###
    .####
    .....
    

    2.3.2 输出#1

    yes
    

    2.3.3 输入#2

    5
    ..###
    ...##
    ..##.
    ##...
    .##..
    

    2.3.4 输出#2

    no
    

    2.4 解题思路

    用char类型的二维数组maze存储输入的迷宫矩阵,用int类型的二维数组visited存储走过的地方,再用int类型的变量flag记录是否走完迷宫,flag初始值设为0,visited所有元素初始值设为0,maze与visited的下标是对应的,如果maze中的地方是#,则可以将visited相同下标元素的值设为1,再深度搜索可能的情况,若判断成功走到终点,则将flag设为1并结束递归。

    2.5 代码

    #include 
    
    using namespace std;
    
    char maze[105][105];
    int visited[105][105],flag=0,n;
    void dfs(int x,int y)//递归搜索函数
    {
        if(x==n-1&&y==n-1)//走到终点的特判条件
        {
            flag = 1;
            return ;
        }
        else
        {
            if(!visited[x-1][y]&&x-1>=0)//上
            {
                visited[x-1][y] = 1;
                dfs(x-1,y);
            }
            if(!visited[x+1][y]&&x+1<=n-1)//下
            {
                visited[x+1][y] = 1;
                dfs(x+1,y);
            }
            if(!visited[x][y-1]&&y-1>=0)//左
            {
                visited[x][y-1] = 1;
                dfs(x,y-1);
            }
            if(!visited[x][y+1]&&y+1<=n-1)//右
            {
                visited[x][y+1] = 1;
                dfs(x,y+1);
            }
        }
    }
    int main()
    {
        cin >> n;
        for(int i=0;ifor(int j=0;j> maze[i][j];
                if(maze[i][j]=='#')
                {
                    visited[i][j] = 1;
                }
            }
        }
        if(visited[0][0]==1||visited[n-1][n-1]==1)
        {
            cout << "no" << endl;
            return 0;
        }
        dfs(0,0);
        if(flag==1) cout << "yes" << endl;
        else cout << "no" << endl;
        return 0;
    }
    
    
  • 相关阅读:
    生成式模型和判别式模型区别
    C++ STL -->string类
    使用并查集解决的相关问题
    减小windows或linux虚拟机导出ova体积大小
    Linux: network: tcp_rmem/rmem_default
    platform驱动模型
    Kali 无法联网的解决方案,优雅的配置桥接模式
    数据中台:数据治理概述
    网络安全行业现在好混吗,工资水平怎么样?
    【软键盘】Android开发之隐藏软键盘的方式
  • 原文地址:https://www.cnblogs.com/TangYuHeng/p/Cpp_DeepFirstSearch_Preliminary.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号