数据结构——python解决迷宫问题(深度优先和广度优先)

文章目录

迷宫问题

栈解决------深度优先------回溯法

python 复制代码
""""""
"""
规定每次按照某种的方式前进
每次前进都将节点的位置存入栈,这样栈中就存放着走过的路线
当不能再继续前进时:后退出栈,直到可以用另一条路可以前进
"""

maze = [
    [0, 1, 0, 0, 0],
    [0, 1, 0, 1, 0],
    [0, 0, 0, 1, 0],
    [0, 1, 1, 1, 0],
    [0, 0, 0, 0, 0]
]

# 前进方式
dirs = [
    lambda x, y: (x - 1, y),
    lambda x, y: (x, y + 1),
    lambda x, y: (x + 1, y),
    lambda x, y: (x, y - 1),
]


def solve(x1, y1, x2, y2):
    stack = []
    stack.append((x1, y1))
    while len(stack):
        current_node = stack[-1]
        if current_node[0] == x2 and current_node[1] == y2:
            for i in stack:
                print(i)
            return True

        for dir in dirs:
            next_node = dir(*current_node)
            if 0 <= next_node[0] < len(maze) and 0 <= next_node[1] < len(maze[0]):
                if maze[next_node[0]][next_node[1]] == 0:
                    stack.append(next_node)
                    maze[next_node[0]][next_node[1]] = 2
                    break
        else:
            maze[next_node[0]][next_node[1]] = 2
            stack.pop()
    else:
        print('没有通路')
        return False


solve(0, 0, 4, 4)

队列解决------广度优先

python 复制代码
""""""
"""
思想:
多条路径同时前进,第一个到达的就是最短路径
通过记录每个节点的上一个节点的位置实现
实现:
一个列表记录此时到达的全部位置(多条路线同时进行就有多个位置),再一个列表所有已经到过的节点位置以及每个节点的上一个位置
"""

from collections import deque

maze = [
    [0, 1, 0, 0, 0],
    [0, 1, 0, 1, 0],
    [0, 0, 0, 1, 0],
    [0, 1, 1, 1, 0],
    [0, 0, 0, 0, 0]
]

# 前进方式
dirs = [
    lambda x, y: (x - 1, y),
    lambda x, y: (x, y + 1),
    lambda x, y: (x + 1, y),
    lambda x, y: (x, y - 1),
]


def print_r(path):
    real_path = []
    real_item_index = len(path) - 1  # real_item:通路上的元素(最开始一定是path的最后一个元素)
    while real_item_index >= 0:
        real_path.append(path[real_item_index][0:2])
        real_item_index = path[real_item_index][2]
    real_path.reverse()
    for node in real_path:
        print(node)


def solve(x1, y1, x2, y2):
    q = deque()
    path = []
    q.append((x1, y1, -1))
    while len(q) > 0:
        current_node = q.popleft()
        path.append(current_node)

        if current_node[0] == x2 and current_node[1] == y2:
            # 到达终点,通过path逐层向前找到完整路径
            print_r(path)
            return True

        for dir in dirs:
            next_node = dir(current_node[0], current_node[1])
            if 0 <= next_node[0] < len(maze) and 0 <= next_node[1] < len(maze[0]):
                if maze[next_node[0]][next_node[1]] == 0:
                    q.append((next_node[0], next_node[1], len(path) - 1))
                    maze[next_node[0]][next_node[1]] = 2
    else:
        print('未找到通路')
        return False


solve(0, 0, 4, 4)

若有错误与不足请指出,关注DPT一起进步吧!!!

相关推荐
Cha0DD2 小时前
【由浅入深探究langchain】第二十集-SQL Agent+Human-in-the-loop
人工智能·python·ai·langchain
Cha0DD2 小时前
【由浅入深探究langchain】第十九集-官方的SQL Agent示例
人工智能·python·ai·langchain
阿豪学编程3 小时前
LeetCode724.:寻找数组的中心下标
算法·leetcode
智算菩萨4 小时前
【Tkinter】4 Tkinter Entry 输入框控件深度解析:数据验证、密码输入与现代表单设计实战
python·ui·tkinter·数据验证·entry·输入框
墨韵流芳4 小时前
CCF-CSP第41次认证第三题——进程通信
c++·人工智能·算法·机器学习·csp·ccf
七夜zippoe4 小时前
可解释AI:构建可信的机器学习系统——反事实解释与概念激活实战
人工智能·python·机器学习·可解释性·概念激活
csdn_aspnet4 小时前
C# 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·算法·c#
凌波粒5 小时前
LeetCode--349.两个数组的交集(哈希表)
java·算法·leetcode·散列表
paeamecium6 小时前
【PAT甲级真题】- Student List for Course (25)
数据结构·c++·算法·list·pat考试
Book思议-6 小时前
【数据结构】栈与队列全方位对比 + C 语言完整实现
c语言·数据结构·算法··队列