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

二叉树的基本概念

二叉树是一种树形数据结构,每个节点最多有两个子节点,分别称为左子节点和右子节点。

  • 特点

    • 每个节点最多有两个子节点。
    • 左子树和右子树有顺序,不可颠倒。
    • 空树(无节点)或由根节点和左右子树组成。
  • 常见术语

    • 根节点:树的顶层节点。
    • 叶子节点:没有子节点的节点。
    • 深度:从根节点到某节点的路径长度。
    • 高度:从某节点到叶子节点的最长路径。

二叉树的遍历方式(C++实现)

遍历是二叉树的核心操作,分为递归和非递归实现。

前序遍历(根-左-右)

递归实现:

cpp 复制代码
void preOrder(TreeNode* root) {
    if (root == nullptr) return;
    cout << root->val << " ";
    preOrder(root->left);
    preOrder(root->right);
}

非递归实现(使用栈):

cpp 复制代码
void preOrderStack(TreeNode* root) {
    stack<TreeNode*> st;
    if (root) st.push(root);
    while (!st.empty()) {
        TreeNode* node = st.top();
        st.pop();
        cout << node->val << " ";
        if (node->right) st.push(node->right);
        if (node->left) st.push(node->left);
    }
}
中序遍历(左-根-右)

递归实现:

cpp 复制代码
void inOrder(TreeNode* root) {
    if (root == nullptr) return;
    inOrder(root->left);
    cout << root->val << " ";
    inOrder(root->right);
}

非递归实现:

cpp 复制代码
void inOrderStack(TreeNode* root) {
    stack<TreeNode*> st;
    TreeNode* curr = root;
    while (curr || !st.empty()) {
        while (curr) {
            st.push(curr);
            curr = curr->left;
        }
        curr = st.top();
        st.pop();
        cout << curr->val << " ";
        curr = curr->right;
    }
}
后序遍历(左-右-根)

递归实现:

cpp 复制代码
void postOrder(TreeNode* root) {
    if (root == nullptr) return;
    postOrder(root->left);
    postOrder(root->right);
    cout << root->val << " ";
}

非递归实现(双栈法):

cpp 复制代码
void postOrderStack(TreeNode* root) {
    stack<TreeNode*> st1, st2;
    if (root) st1.push(root);
    while (!st1.empty()) {
        TreeNode* node = st1.top();
        st1.pop();
        st2.push(node);
        if (node->left) st1.push(node->left);
        if (node->right) st1.push(node->right);
    }
    while (!st2.empty()) {
        cout << st2.top()->val << " ";
        st2.pop();
    }
}

二叉树常见考点

  1. 求二叉树的最大深度
cpp 复制代码
int maxDepth(TreeNode* root) {
    if (root == nullptr) return 0;
    return 1 + max(maxDepth(root->left), maxDepth(root->right));
}
  1. 判断对称二叉树
cpp 复制代码
bool isSymmetric(TreeNode* root) {
    if (!root) return true;
    return helper(root->left, root->right);
}

bool helper(TreeNode* left, TreeNode* right) {
    if (!left && !right) return true;
    if (!left || !right) return false;
    return (left->val == right->val) && 
           helper(left->left, right->right) && 
           helper(left->right, right->left);
}
  1. 二叉树的层序遍历(BFS)
cpp 复制代码
vector<vector<int>> levelOrder(TreeNode* root) {
    vector<vector<int>> res;
    if (!root) return res;
    queue<TreeNode*> q;
    q.push(root);
    while (!q.empty()) {
        int size = q.size();
        vector<int> level;
        for (int i = 0; i < size; ++i) {
            TreeNode* node = q.front();
            q.pop();
            level.push_back(node->val);
            if (node->left) q.push(node->left);
            if (node->right) q.push(node->right);
        }
        res.push_back(level);
    }
    return res;
}
  1. 重建二叉树(前序+中序)
cpp 复制代码
TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {
    unordered_map<int, int> inMap;
    for (int i = 0; i < inorder.size(); ++i) {
        inMap[inorder[i]] = i;
    }
    return helper(preorder, 0, preorder.size()-1, inorder, 0, inorder.size()-1, inMap);
}

TreeNode* helper(vector<int>& preorder, int preStart, int preEnd, 
                 vector<int>& inorder, int inStart, int inEnd, 
                 unordered_map<int, int>& inMap) {
    if (preStart > preEnd || inStart > inEnd) return nullptr;
    TreeNode* root = new TreeNode(preorder[preStart]);
    int inRoot = inMap[root->val];
    int numsLeft = inRoot - inStart;
    root->left = helper(preorder, preStart+1, preStart+numsLeft, 
                        inorder, inStart, inRoot-1, inMap);
    root->right = helper(preorder, preStart+numsLeft+1, preEnd, 
                         inorder, inRoot+1, inEnd, inMap);
    return root;
}

考试高频题型

  1. 递归应用:如遍历、深度计算、对称判断。
  2. 非递归实现:栈模拟递归过程(前中后序遍历)。
  3. 构造二叉树:根据前序/中序/后序序列重建。
  4. 特殊二叉树:二叉搜索树(BST)、平衡二叉树(AVL)的性质与操作。
  5. 路径问题:如求根到叶子节点的路径和。

掌握上述核心代码和逻辑,可覆盖多数二叉树相关考题。

相关推荐
田梓燊17 分钟前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
invicinble23 分钟前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
wbs_scy38 分钟前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
re林檎41 分钟前
算法札记——4.27
算法
ss2731 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记1 小时前
逻辑回归与Softmax回归
算法·回归·逻辑回归
try2find2 小时前
打印ascii码报错问题
java·linux·前端
014-code2 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
Nicander2 小时前
多数据源下@transcation事务踩坑
java·后端