二叉树的遍历算法之先序遍历

我们先来熟悉一下二叉树的概念:二叉树是‌每个节点最多有两个子树‌的树形数据结构,通常分为左子树和右子树。

先序遍历

先序遍历就是先访问根节点,然后遍历左子树,最后遍历右子树。

二叉树的先序遍历的递归实现

该版本是二叉树深度优先搜索最常见的实现方式。

其基本思路是:

  1. 访问当前节点。
  2. 递归遍历当前节点的左子树。(由于栈的先进后出性质,所以先将右子树入栈,后将左子树入栈,出栈的时候是左子树先出栈,右子树后出栈,符合先序遍历的顺序。)
  3. 递归遍历当前节点的右子树。
复制代码
def dfs_preorder(root):
    if root is None:
        return
    print(root.val)             # 访问当前节点。
    dfs_preorder(root.left)     # 递归遍历当前节点的左子树。
    dfs_preorder(root.right)    # 递归遍历当前节点的右子树。
相关推荐
liu****1 小时前
第16届国赛蓝桥杯大赛C/C++大学B组
c语言·数据结构·c++·算法·蓝桥杯
SimpleLearingAI1 小时前
大模型推理框架总结解析
算法
Σίσυφος19001 小时前
正则化数据并校准数据
人工智能·算法·机器学习
HZ·湘怡1 小时前
基于动态数组的栈(顺序栈)01
数据结构·算法
Chen_harmony1 小时前
十八、C语言内存函数
c语言·算法
__Coffee__2 小时前
封装矩阵结构体
线性代数·算法·矩阵
变量未定义~2 小时前
字符串哈希匹配字符串
数据结构·算法·哈希算法
周末也要写八哥2 小时前
浅谈二叉树的深度优先搜索(DFS)算法
算法·深度优先
y = xⁿ2 小时前
20天速通LeetCodeday17:一维动态规划
算法