题解 | #迷宫问题#

迷宫问题

http://www.nowcoder.com/practice/cf24906056f4488c9ddb132f317e03bc

简单dfs寻路

while (line = readline()) {
    let nums = line.split(' ');
    let col = +nums[0];
    let row = +nums[1];
    let map = [];
    for (let i = 0; i < col; i++) {
        map.push([]);
        let mapline = readline().split(' ');
        for (let j = 0; j < row; j++) {
            map[i][j] = +mapline[j];
        }
    }
    let minLine = [];
    let nowLine = [];
    let dir = [[0, 1], [0, -1], [1, 0], [-1, 0]];
    let book = [];
    for (let i = 0; i < col; i++) {
        book.push([]);
        for (let j = 0; j < row; j++) {
            book[i][j] = 0;
        }
    }
    let dfs = (x, y) => {
        nowLine.push(`(${x},${y})`);
        book[x][y] = 1;
        if (x == col - 1 && y == row - 1) {
            if (minLine.length == 0 || nowLine.length < minLine.length) {
                minLine = [];
                for (let i = 0; i < nowLine.length; i++) {
                    minLine[i] = nowLine[i];
                }
            }
            book[x][y] = 0;
            nowLine.pop();
            return;
        }
        for (let i = 0; i < 4; i++) {
            let tox = x + dir[i][0];
            let toy = y + dir[i][1];
            if (tox >= 0 && tox < col && toy >= 0 && toy < row && map[tox][toy] == 0 && book[tox][toy] == 0) {
                dfs(tox, toy);
            }
        }
        book[x][y] = 0;
        nowLine.pop();
        return;
    }
    dfs(0, 0);
    for (let i = 0; i < minLine.length; i++) {
        console.log(minLine[i]);
    }
}

全部评论
逻辑这么复杂的
点赞 回复 分享
发布于 2022-11-22 01:26 湖北

相关推荐

许愿ssp的咸鱼很不想泡池子:import python as pyhton
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务