JS解决迷宫老鼠算法

简介: JS解决迷宫老鼠算法题解决。

您好,如果喜欢我的文章,可以关注我的公众号「量子前端」,将不定期关注推送前端好文~

题目:假设我们有一个大小为NxN的矩阵,矩阵每一个位置是一个方块。每个位置可以是1(可通行)或0(阻挡的),maze[0][0]为起点,maze[n][n]为终点,判断是否可以从起点顺路通往终点。

const maze = [
    [1,0,0,0],
    [1,1,1,1],
    [0,0,0,1],
    [0,1,0,1]
]
var flag = false;
function test(maze, nowX, nowY) {
   
   
    if(maze[0][0] == 0) return false;       //如果起点不通,false
    let nowWay;       //正在走哪条路
    if(nowX == maze.length - 1 && nowY == maze[0].length - 1 && maze[nowX][nowY] == 1) {
   
           //如果到终点,并且终点为1
        flag =  true;
        return flag;
    } else {
   
   
        if(nowX == maze.length - 1 && maze[nowX][nowY + 1] == 0 ) {
   
            //如果到了最下排,并且往右走不通
            if(!nowWay) {
   
              //如果已经被清空标记点,无路可换
                return false;
            }
            nowWay = '';                //清空移动方向,回退,重新选择路,并把此点标为0
            maze[nowX][nowY] = 0;
            test(maze, nowX - 1, nowY) 
        }
        if(nowX !== maze.length - 1 && maze[nowX + 1][nowY] == 1 ) {
   
           //如果到了最右排,并且下面可以走
            nowWay = 'x';
            test(maze, nowX + 1, nowY)
        }
        if(nowY !== maze[0].length - 1 && maze[nowX][nowY + 1] == 1 ) {
   
        //如果到了最下排,并且右面可以走
            nowWay = 'y';
            test(maze, nowX, nowY + 1)
        }
    }
    return flag;
}
console.log('迷宫为:', maze)
console.log(test(maze, 0, 0))

可通行:
请添加图片描述
不可通行:
请添加图片描述
如果有更好的解题思路,欢迎留言。

目录
相关文章
|
2天前
|
算法 JavaScript 前端开发
LZH 算法的模拟实现,JavaScript 版本
LZH 算法的模拟实现,JavaScript 版本
15 0
|
2天前
|
算法 JavaScript 前端开发
彩票中奖率的真相:用 JavaScript 看透彩票背后的随机算法(下)
至于分发?我们可以参考一下市面上已有的一些概念做一下对比,下面是笼统的一个网络服务器的TPS预估值,也就是说彩票服务器在1秒内可以处理的最大请求数:
|
2天前
|
数据采集 算法 JavaScript
彩票中奖率的真相:用 JavaScript 看透彩票背后的随机算法(上)
原本这篇文章是打算叫「假如我是彩票系统开发者」,但细想一下,如果在文章中引用太多的 JavaScript 的话,反而不是那么纯粹,毕竟也只是我的一厢情愿,彩票开发也不全如本文所讲,有所误导的话便也是得不偿失了。
|
2天前
|
JavaScript 前端开发 算法
JavaScript的垃圾回收机制通过标记-清除算法自动管理内存
【5月更文挑战第11天】JavaScript的垃圾回收机制通过标记-清除算法自动管理内存,免除开发者处理内存泄漏问题。它从根对象开始遍历,标记活动对象,未标记的对象被视为垃圾并释放内存。优化技术包括分代收集和增量收集,以提升性能。然而,开发者仍需谨慎处理全局变量、闭包、定时器和DOM引用,防止内存泄漏,保证程序稳定性和性能。
17 0
|
2天前
|
算法 JavaScript 前端开发
三个js算法
三个js算法
8 2
|
2天前
|
算法 JavaScript
js的两个常用算法
js的两个常用算法
5 1
|
2天前
|
JavaScript 前端开发 算法
【JavaScript技术专栏】使用JavaScript实现常见算法
【4月更文挑战第30天】本文介绍了如何使用JavaScript实现常见算法,包括排序、搜索和图算法。首先,通过JavaScript的`sort`方法讨论了排序算法,以快速排序为例展示了自定义排序的实现。接着,探讨了二分查找这一高效的搜索算法,并提供了实现代码。最后,解释了深度优先搜索(DFS)图算法,并给出了在JavaScript中的实现。理解并运用这些算法能有效提升编程能力。
|
2天前
|
算法 JavaScript 前端开发
游戏物理系统 - 如何在JavaScript中实现基本的碰撞检测算法?
在JavaScript中实现2D矩形碰撞检测,常用AABB方法,适合简单游戏。创建Rectangle类,包含位置和尺寸属性,并定义`collidesWith`方法检查两矩形是否相交。通过比较边界位置判断碰撞,当四条边界条件均满足时,认定发生碰撞。基础算法适用于初级需求,复杂场景可采用更高级的碰撞检测库。
14 1
|
2天前
|
缓存 JavaScript 算法
Vue.js中的diff算法:让虚拟DOM更高效
Vue.js中的diff算法:让虚拟DOM更高效
|
2天前
|
算法 JavaScript