当前位置: 首页 > article >正文

LeetCode Hot100 | Day6 | 从前序和中序数组构建二叉树

LeetCode Hot100 | Day6 | 从前序和中序数组构建二叉树

从前序和中序数组构建二叉树

105. 从前序与中序遍历序列构造二叉树 - 力扣(LeetCode)

class Solution {
public:
    TreeNode *tra(vector<int> preorder, vector<int> inorder)
    {
        if(preorder.size()==0)
            return nullptr;
        int val=preorder[0];
        TreeNode* t=new TreeNode (val);
        int index=0;
        for(index=0;index<inorder.size();index++)
            if(val==inorder[index])
                break;
        t->left=tra(vector<int>(preorder.begin()+1,preorder.begin()+1+index),vector<int>(inorder.begin(),inorder.begin()+index));
        t->right=tra(vector<int>(preorder.begin()+1+index,preorder.end()),vector<int>(inorder.begin()+index+1,inorder.end()));
        return t;
    }
    TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {
        return tra(preorder,inorder);
    }
};

读者可以参考这篇博客来学习本题解法,思路都一样

代码随想录 | Day25 | 二叉树:从中序与后序遍历构造二叉树&&最大二叉树-CSDN博客

注意点:切割子树的前序和中序区间的时候要注意使用的区间要统一

前闭后开就全都前闭后开

前开后闭就全都前开后闭


http://www.kler.cn/news/359422.html

相关文章:

  • 使用短效IP池的优势是什么?
  • Axure显示与隐藏——元件动作一
  • 面对AI算力需求激增,如何守护数据中心机房安全?
  • Linux系统:tac命令
  • 红日靶机(五)笔记
  • ES2017 新特性 (Async和await)
  • 【从零开始的LeetCode-算法】3099. 哈沙德数
  • Lua环境安装
  • 人工智能:塑造未来生活与工作的力量
  • 链表的基本操作(FreeRTOS基础)
  • SpringBoot智能推荐:健康生活新选择
  • 大话哈希冲突
  • 【Flutter】基础入门:Widgets
  • 免费开源AI助手,颠覆你的数字生活体验
  • 从苏宁电器到卡巴斯基(第二部)第37篇:我当高校教师的这几年 XIII
  • 快速排序入门
  • 开源的AI博客生成工具,支持网页URL、文本转换成博客
  • 《编程入门与提高:开启数字世界的大门》
  • 10.10-10.13学习
  • linux:DMA( Direct Memory Access,直接内存访问)