输入某二叉树的前序遍历和中序遍历的结果。请重建二叉树,假设输入的前序遍历和中序遍历的结果都不包含重复的数字

输入某二叉树的前序遍历和中序遍历的结果。请重建二叉树,假设输入的前序遍历和中序遍历的结果都不包含重复的数字使用c++解决

#include <iostream>
#include <vector>
#include <unordered_map>

// 定义二叉树节点结构
struct TreeNode {
    int val; // 节点的值
    TreeNode *left; // 左子树指针
    TreeNode *right; // 右子树指针
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} // 构造函数,初始化节点值,并将左右子树指针设为 nullptr
};

class Solution {
public:
    // 主函数,用于根据前序和中序遍历构建二叉树
    TreeNode* buildTree(std::vector<int>& preorder, std::vector<int>& inorder) {
        int preIndex = 0; // 初始化前序遍历索引
        // 调用辅助函数构建二叉树
        return buildTreeHelper(preorder, inorder, preIndex, 0, inorder.size() - 1);
    }

private:
    // 辅助函数,用于递归构建二叉树
    TreeNode* buildTreeHelper(const std::vector<int>& preorder, const std::vector<int>& inorder,
                              int& preIndex, int inStart, int inEnd) {
        if (inStart > inEnd) return nullptr; // 如果中序遍历的起始索引大于结束索引,返回 nullptr

        int rootValue = preorder[preIndex++]; // 获取当前子树的根节点值,并更新前序遍历索引
        TreeNode* root = new TreeNode(rootValue); // 创建根节点

        // 在中序遍历中找到根节点的位置
        int inIndex = inStart;
        while (inIndex <= inEnd && inorder[inIndex] != rootValue) {
            ++inIndex; // 遍历中序遍历数组,找到根节点的位置
        }

        // 递归构建左子树
        root->left = buildTreeHelper(preorder, inorder, preIndex, inStart, inIndex - 1);
        // 递归构建右子树
        root->right = buildTreeHelper(preorder, inorder, preIndex, inIndex + 1, inEnd);

        return root; // 返回构建好的树的根节点
    }
};

// 用于测试:中序遍历打印重建的树
void inorderTraversal(TreeNode* root) {
    if (root == nullptr) return; // 如果根节点为空,直接返回
    inorderTraversal(root->left); // 递归遍历左子树
    std::cout << root->val << " "; // 打印当前节点值
    inorderTraversal(root->right); // 递归遍历右子树
}

int main() {
    std::vector<int> preorder = {3, 9, 20, 15, 7}; // 定义前序遍历数组
    std::vector<int> inorder = {9, 3, 15, 20, 7}; // 定义中序遍历数组

    Solution solution; // 创建 Solution 类的实例
    TreeNode* root = solution.buildTree(preorder, inorder); // 构建二叉树

    std::cout << "重建的二叉树的中序遍历结果:"; // 输出提示
    inorderTraversal(root); // 中序遍历打印二叉树
    std::cout << std::endl; // 输出换行符

    return 0; // 返回 0 表示程序执行成功
}

上面是递归的方法

下面使用非递归的方法

#include <iostream>
#include <vector>
#include <stack>

// 定义二叉树节点结构
struct TreeNode {
    int val;
    TreeNode *left;
    TreeNode *right;
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};

class Solution {
public:
    TreeNode* buildTree(std::vector<int>& preorder, std::vector<int>& inorder) {
        if (preorder.empty()) return nullptr; // 如果前序遍历为空,直接返回 nullptr

        std::stack<TreeNode*> stk; // 创建一个栈来模拟递归
        TreeNode* root = new TreeNode(preorder[0]); // 创建根节点
        stk.push(root); // 将根节点推入栈中

        int inorderIndex = 0; // 中序遍历的索引

        for (int i = 1; i < preorder.size(); ++i) {
            int preValue = preorder[i];
            TreeNode* node = stk.top(); // 获取栈顶元素

            if (node->val != inorder[inorderIndex]) {
                node->left = new TreeNode(preValue); // 创建左子节点
                stk.push(node->left); // 将左子节点推入栈中
            } else {
                while (!stk.empty() && stk.top()->val == inorder[inorderIndex]) {
                    node = stk.top();
                    stk.pop();
                    ++inorderIndex;
                }
                node->right = new TreeNode(preValue); // 创建右子节点
                stk.push(node->right); // 将右子节点推入栈中
            }
        }

        return root; // 返回根节点
    }
};

// 用于测试:中序遍历打印重建的树
void inorderTraversal(TreeNode* root) {
    if (root == nullptr) return;
    inorderTraversal(root->left);
    std::cout << root->val << " ";
    inorderTraversal(root->right);
}

int main() {
    std::vector<int> preorder = {3, 9, 20, 15, 7}; // 定义前序遍历数组
    std::vector<int> inorder = {9, 3, 15, 20, 7}; // 定义中序遍历数组

    Solution solution; // 创建 Solution 类的实例
    TreeNode* root = solution.buildTree(preorder, inorder); // 构建二叉树

    std::cout << "重建的二叉树的中序遍历结果:"; // 输出提示
    inorderTraversal(root); // 中序遍历打印二叉树
    std::cout << std::endl; // 输出换行符

    return 0; // 返回 0 表示程序执行成功
}

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以通过的结果重建叉树,然后对重建后的二叉树进行后,即可得到所求的后结果。具体步骤如下: 1. 根据的结果确定二叉树的根节点。 2. 在的结果找到根节点的位置,将结果分为左子树和右子树两部分。 3. 根据左子树的结果递归重建左子树。 4. 根据右子树的结果递归重建右子树。 5. 将左子树和右子树连接到根节点上,得到重建后的二叉树。 6. 对重建后的二叉树进行后,得到所求的后结果。 需要注意的是,如果结果存在重复元素,那么需要根据的顺来确定左子树和右子树的范围。 ### 回答2: 给定一棵二叉树的结果,求其后的方法比较简单,可以通过递归的方式解决。首先,我们需要了解一下和后的概念: 1.:先访问根节点,然后按照左子树、右子树的顺整个二叉树。 2.:按照左子树、根节点、右子树的顺整个二叉树。 3.后:按照左子树、右子树、根节点的顺整个二叉树。 在给定的情况下,我们可以根据数组第一个元素为根节点,然后再根据数组找到根节点的位置,从而确定左右子树的大小,然后递归构建左右子树。最后,将左子树的后、右子树的后和根节点拼接在一起即为所求的后。 下面是具体的步骤: 1.根据数组,找到根节点,并创建一个新的节点。 2.在数组找到根节点的位置,确定左子树和右子树的大小。 3.递归构建左子树和右子树。 4.将左子树的后、右子树的后和根节点一起拼接起来,得到整棵树的后。 下面是具体的实现代码: ```python class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def buildTree(preorder, inorder): if not preorder: return None root = TreeNode(preorder[0]) idx = inorder.index(preorder[0]) root.left = buildTree(preorder[1:idx+1], inorder[:idx]) root.right = buildTree(preorder[idx+1:], inorder[idx+1:]) return root def postorderTraversal(root): if not root: return [] else: return postorderTraversal(root.left) + postorderTraversal(root.right) + [root.val] preorder = [1, 2, 4, 5, 3, 6, 7] inorder = [4, 2, 5, 1, 6, 3, 7] root = buildTree(preorder, inorder) print(postorderTraversal(root)) #[4, 5, 2, 6, 7, 3, 1] ``` 运行结果为:[4, 5, 2, 6, 7, 3, 1],与我们预期的后结果一致。 总结:给定一棵二叉树的结果,求其后的方法,可以通过递归的方式实现。通过数组找到根节点,再根据数组确定左右子树大小,递归构建左右子树,并将左子树的后、右子树的后和根节点拼接在一起,得到整棵树的后。 ### 回答3: 二叉树为根节点、左子树、右子树;为左子树、根节点、右子树;后为左子树、右子树、根节点。因此,我们可以通过来构建出二叉树,再通过后输出二叉树的遍结果。 具体步骤如下: 1. 按照得到根节点的值; 2. 在找到根节点的位置,从而确定左右子树的; 3. 根据左右子树的确定左右子树的范围; 4. 递归构建左右子树; 5. 输出后结果。 代码如下: ``` def buildTree(preorder, inorder): if not inorder: return None root_val = preorder.pop(0) root = TreeNode(root_val) index = inorder.index(root_val) root.left = buildTree(preorder, inorder[:index]) root.right = buildTree(preorder, inorder[index+1:]) return root def postorderTraversal(root): res = [] if not root: return res res.extend(postorderTraversal(root.left)) res.extend(postorderTraversal(root.right)) res.append(root.val) return res preorder = [1, 2, 4, 5, 3, 6, 7] inorder = [4, 2, 5, 1, 6, 3, 7] root = buildTree(preorder, inorder) print(postorderTraversal(root)) # 输出:[4, 5, 2, 6, 7, 3, 1] ``` 上述代码的 `buildTree` 函数用于根据构建二叉树,返回根节点;`postorderTraversal` 函数用于输出二叉树的后结果,采用先递归遍左右子树的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值