python实现二叉树的广度优先遍历(BFS)和深度优先遍历(DFS)

本文详细介绍了如何使用Python3实现二叉树的广度优先遍历(BFS)和深度优先遍历(DFS)。通过队列实现BFS,栈实现DFS,遵循各自的数据结构特性进行节点的遍历。测试结果显示了正确的遍历顺序。
摘要由CSDN通过智能技术生成

本文用python3实现二叉树的广度优先遍历(BFS)和深度优先遍历(DFS)。

完整代码链接:https://github.com/toanoyx/BasicAlgorithm/tree/master/tree

广度优先遍历

广度遍历又叫层次遍历。用队列实现,依次将根,左子树,右子树存入队列,按照队列的先进先出规则来实现层次遍历。

# 层次遍历(广度优先)
def BFS(root):
    if root:
        res = []
        queue = [root]
        while queue:
            currentNode = queue.pop(0)
            res.append(currentNode.val)
            if currentNode.left:
                queue.append(currentNode.left)
            if currentNode.right:
                queue.append(currentNode.right)
    return res

深度优先遍历

用栈实现,先将根入栈,再将根出栈,并将根的右子树,左子树存入栈,按照栈的先进后出规则来实现深度优先遍历。

# 深度优先
def DFS(root):
    if root:
        res = []
        stack = [root
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值