当前位置: 首页 > article >正文

基于C++深度优先遍历迷宫

c++实现的深度优先遍历迷宫,迷宫大小为20*20,代码简练清楚,内涵关键注释。代码与网上都不一样。

深度优先遍历迷宫,核心思想是借助一个栈,站在一个节点上时,将它附近可以走的节点存在栈中,再按顺序找到下一个节点,重复刚才的操作,直到找到最终的终点。

实现细节

  • Stack函数不需要多说了,自己定义一个栈,这个栈是很关键的,像我刚才说的,他用来记录去过的节点,以保证不重不漏
  • 重点是slove函数,slove()原理:
    递归出口为找到出口或者没有出口的条件下整个地图被全部遍历将入口读出;分别进行上下左右移动并判定是否可走;如果可走则将其压栈,并递归;否则返回上一步。这是一个递归函数,因此深度优先本身的效率不高。
    对于一个节点,坐标(x,y),我们这里规定只允许向四个方向移动,所以需要找的坐标是(x-1,y),(x+1,y)(x,y-1),(x,y+1),分别判断是否可以去,且是否去过,这就是本项目中最重要的地方了!
void slove(zuobiao c,Stack &a,int (*Map)[20]){
    zuobiao l=a.ntop();
    if(l.x==c.x&&l.y==c.y){
        return ;
    }
    if(pass(l.x,l.y+1,Map)){
        zuobiao m;
        m.x=l.x;m.y=l.y+1;
        vi[m.x][m.y]=1;
        a.push(m);  

        slove(c,a,Map);
    }
    else if(pass(l.x,l.y-1,Map)){
        zuobiao m;
        m.x=l.x;m.y=l.y-1;
        vi[m.x][m.y]=1;
        a.push(m);  

        slove(c,a,Map);
    }
    else if(pass(l.x-1,l.y,Map)){ 
        zuobiao m;
        m.x=l.x-1;m.y=l.y;
        vi[m.x][m.y]=1;
        a.push(m);  

        slove(c,a,Map);
    }
    else if(pass(l.x+1,l.y,Map)){
        zuobiao m;
        m.x=l.x+1;m.y=l.y;
        vi[m.x][m.y]=1;
        a.push(m);  

        slove(c,a,Map);
    }
    else {
        if(a.bout()){
            slove(c,a,Map);
        }
        else {
            cout<<"没有路径可以到达指定的地点";
        }
    }
}


http://www.kler.cn/a/383743.html

相关文章:

  • 代码随想录第二十三天
  • lsblk 命令学习
  • 使用代理时Stable Diffusion无法正常下载各类模型的解决办法
  • 是时候用开源降低AI落地门槛了
  • C++(二)
  • 【实用教程】Blazor 文件管理器中引入分页功能
  • 如何将数据从 AWS S3 导入到 Elastic Cloud - 第 3 部分:Elastic S3 连接器
  • Java 8 Stream用法与常见问题和解决方式
  • Redis内存管理——针对实习面试
  • Charles简单压力测试
  • Unity中RTS游戏的设计模式处理: 游戏中的对象选择和命令委托的基本框架
  • 解读JobScheduler的jobs.xml
  • 判断二叉搜索树(递归)
  • 【LeetCode】【算法】647. 回文子串
  • 卡码网KamaCoder 127. 骑士的攻击
  • 梧桐数据库之查询特定日期的套餐价格分享
  • (超级详细版)Java基础:Java常用变量详解
  • T507 buildroot linux4.9之MCP2515 can网络开发调试
  • 耕地类项目知识点汇总(持续完善中……)
  • ubuntu22.04安装conda
  • 鸿蒙-promptAction.showToast基于PC屏幕底部提示
  • Ubuntu 安装 RTL8811cu 网卡驱动
  • CTFshow之信息收集第1关到10关。详细讲解
  • SpringBoot基础系列学习(二):配置详解
  • 汉诺塔问题代码分享及思路分享(c基础)
  • Spring Cloud微服务:构建弹性、可扩展的分布式系统