二叉树简述+考试要点(Python)

二叉树基本概念

二叉树是一种树形数据结构,每个节点最多有两个子节点(左子节点和右子节点)。常见类型包括:

  • 满二叉树:所有非叶子节点都有两个子节点,且所有叶子节点在同一层。
  • 完全二叉树:除最后一层外,其他层节点数达到最大,最后一层节点从左向右填充。
  • 二叉搜索树(BST):左子树所有节点值小于根节点,右子树所有节点值大于根节点。

Python实现二叉树节点

python 复制代码
class TreeNode:
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right

常见考试要点

二叉树的遍历(递归与非递归)
  • 前序遍历 :根→左→右

    python 复制代码
    def preorder(root):
        if not root:
            return []
        return [root.val] + preorder(root.left) + preorder(root.right)
  • 中序遍历 :左→根→右(BST中结果为有序序列)

    python 复制代码
    def inorder(root):
        if not root:
            return []
        return inorder(root.left) + [root.val] + inorder(root.right)
  • 后序遍历 :左→右→根

    python 复制代码
    def postorder(root):
        if not root:
            return []
        return postorder(root.left) + postorder(root.right) + [root.val]
二叉树的高度与深度
python 复制代码
def max_depth(root):
    if not root:
        return 0
    return 1 + max(max_depth(root.left), max_depth(root.right))
判断平衡二叉树

平衡二叉树定义为左右子树高度差不超过1。

python 复制代码
def is_balanced(root):
    def check(node):
        if not node:
            return 0
        left = check(node.left)
        right = check(node.right)
        if left == -1 or right == -1 or abs(left - right) > 1:
            return -1
        return 1 + max(left, right)
    return check(root) != -1
二叉搜索树操作
  • 验证BST :利用中序遍历是否有序。

    python 复制代码
    def is_valid_bst(root, min_val=float('-inf'), max_val=float('inf')):
        if not root:
            return True
        if root.val <= min_val or root.val >= max_val:
            return False
        return (is_valid_bst(root.left, min_val, root.val) and 
                is_valid_bst(root.right, root.val, max_val))
  • 插入节点 :递归或迭代实现。

    python 复制代码
    def insert_into_bst(root, val):
        if not root:
            return TreeNode(val)
        if val < root.val:
            root.left = insert_into_bst(root.left, val)
        else:
            root.right = insert_into_bst(root.right, val)
        return root
二叉树序列化与反序列化
python 复制代码
def serialize(root):
    if not root:
        return "None"
    return f"{root.val},{serialize(root.left)},{serialize(root.right)}"

def deserialize(data):
    def helper(nodes):
        val = next(nodes)
        if val == "None":
            return None
        node = TreeNode(int(val))
        node.left = helper(nodes)
        node.right = helper(nodes)
        return node
    nodes = iter(data.split(','))
    return helper(nodes)

高频考题示例

  1. 求二叉树的最大路径和(LeetCode 124)。
  2. 最近公共祖先(LCA)问题(LeetCode 236)。
  3. 层序遍历(BFS)及其变种(如锯齿形遍历)。
  4. 根据前序和中序遍历序列重建二叉树(LeetCode 105)。

掌握以上内容可覆盖多数二叉树相关考试题目,建议结合递归和迭代两种方法练习。

相关推荐
zhangchaoxies2 分钟前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
曲幽11 分钟前
FastAPI + Pydantic 模型终极实战手册:从能跑就行到固若金汤,这些技巧你一定用得上
python·fastapi·web·model·field·pydantic·validator·basemodel
Halo_tjn15 分钟前
Java 基于字符串相关知识点
java·开发语言·算法
梦想的颜色20 分钟前
java 利用redis来限制用户频繁点击
java·开发语言
报错小能手22 分钟前
Swift 并发 Combine响应式框架
开发语言·ios·swift
计算机软件程序设计1 小时前
Python Flask工程目录解读
python·flask·工程目录解读
Ares-Wang1 小时前
Flask》》 Flask-OpenID 认证、 OpenID Connect (OIDC)
后端·python·flask
万法若空1 小时前
C++ <memory> 库全方位详解
开发语言·c++
代码中介商1 小时前
C++ 类型转换深度解析:static_cast、dynamic_cast、const_cast、reinterpret_cast
开发语言·c++
青小莫1 小时前
C++之string(OJ练习)
开发语言·c++·stl