题解 | 二叉树遍历

#include<iostream>
#include<string>
using namespace std;

typedef struct TreeNode {
    char data;
    TreeNode* leftChild;
    TreeNode* rightChild;
} TreeNode;

void createTree(TreeNode* root, string preOrder, string inOrder) {
    if (preOrder.size() != 0) {
        //给根赋值
        root->leftChild = NULL;
        root->rightChild = NULL;
        root->data = preOrder[0];
        // 寻找左右子树子串
        int index;
        for (unsigned int i = 0; i < inOrder.size(); i++) {
            if (inOrder[i] == preOrder[0]) {
                index = i;  // 左子树长度为index 右子树长度为inOrder.size() - index - 1
            }
        }

        string sub_left_preOrder = preOrder.substr(1, index);
        string sub_left_inOrder = inOrder.substr(0, index);
        string sub_right_preOrder = preOrder.substr(index + 1,
                                    inOrder.size()   - index - 1);
        string sub_right_inOrder = inOrder.substr(index + 1,
                                   inOrder.size() - index - 1);

        // 递归创建左右子树
        if (sub_left_preOrder.size() != 0) {
            root->leftChild = (TreeNode*)malloc(sizeof(TreeNode));
            createTree(root->leftChild, sub_left_preOrder, sub_left_inOrder);
        }
        if (sub_right_preOrder.size() != 0) {
            root->rightChild = (TreeNode*)malloc(sizeof(TreeNode));
            createTree(root->rightChild, sub_right_preOrder, sub_right_inOrder);
        }
    }
}

void PostOrder(TreeNode* root) {
    if (root != NULL) {
        PostOrder(root->leftChild);
        PostOrder(root->rightChild);
        cout << root->data;
    }
}

int main() {
    string preOrder, inOrder;
    TreeNode* root;
    while (cin >> preOrder && cin >> inOrder) {
        root = (TreeNode*)malloc(sizeof(
                                     TreeNode));// 务必在外面建立好root不然会传递给空指针
        createTree(root, preOrder, inOrder);
        PostOrder(root);
        cout << endl;
    }
}

全部评论

相关推荐

线性袋鼠:别听牛客上一帮伪人在那说,小厂不能去,必须去大厂,听他们放屁吧。学院本+一些一本最终的归宿就是中小厂,大厂那么好进吗
我的实习日记
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务