• 七:重建二叉树(依据先序遍历(或者后序遍历)和中序遍历重建二叉树)


    对于一颗二叉树。能够依据先序遍历(或者后序遍历)和中序遍历(树中不含反复的数字)又一次还原出二叉树。


    解析:

    1. 先序遍历序列的第一个元素必然是根节点,能够由此获取二叉树的根节点。


    2. 依据根节点,在中序遍历序列中查找该节点,由中序遍历的性质可知,中序遍历中该根节点左边的序列必然在根节点的左子树中。而根节点右边的序列必然在右子树中。由此能够知道先序遍历中左子树以及右子树的起止位置。


    3. 找到了左右子树前序遍历和中序遍历再用相同的方法分别构建左右子树,典型的递归思想。


    代码例如以下:

    BinaryTreeNode* ConstructCore

    (

       int* startPreorder, int* endPreorder,

       int* startInorder, int* endInorder

    )

    {

       // 前序遍历序列的第一个数字是根结点的值

       int rootValue = startPreorder[0];

       BinaryTreeNode* root = new BinaryTreeNode();

       root->m_nValue = rootValue;

       root->m_pLeft = root->m_pRight = NULL;

     

       if(startPreorder == endPreorder)

        {

           if(startInorder == endInorder && *startPreorder ==*startInorder)

               return root;

           else

               throw std::exception("Invalid input.");

        }

     

       // 在中序遍历中找到根结点的值

       int* rootInorder = startInorder;

       while(rootInorder <= endInorder && *rootInorder != rootValue)

           ++ rootInorder;

       //推断是否找到根节点

       if(rootInorder == endInorder && *rootInorder != rootValue)

           throw std::exception("Invalid input.");

     

       int leftLength = rootInorder - startInorder;

       int* leftPreorderEnd = startPreorder + leftLength;

       if(leftLength > 0)

        {

           // 构建左子树

           root->m_pLeft = ConstructCore(startPreorder + 1, leftPreorderEnd,

               startInorder, rootInorder - 1);

        }

        if((leftLength+ startPreorder)< endPreorder )    {

           // 构建右子树

           root->m_pRight = ConstructCore(leftPreorderEnd + 1, endPreorder,

               rootInorder + 1, endInorder);

        }

     

       return root;

    }

     

    BinaryTreeNode* Construct(int* preorder,int* inorder, int length)

    {

       if(preorder == NULL || inorder == NULL || length <= 0)

           return NULL;

     

       return ConstructCore(preorder, preorder + length - 1,

           inorder, inorder + length - 1);

    }

     


    注:《剑指offer》学习总结

  • 相关阅读:
    浅谈ES6
    iframe的应用
    vue时时监听input输入框中 输入内容 写法
    点击模态框滑动出来 抽屉
    this.$router 和this.$route 的区别
    iview框架 两侧弹框 出现第二层弹框 一闪而过的问题
    input框中的必填项之取消当前input框为必填项
    v-model 的修饰符
    单页面开发和多页面开发的优缺点
    原型继承+借用构造函数继承 的一些理解
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/6940210.html
Copyright © 2020-2023  润新知