letcode 分类练习 513.找树左下角的值 112. 路径总和 106.从中序与后序遍历序列构造二叉树

letcode 分类练习 513.找树左下角的值 112. 路径总和 106.从中序与后序遍历序列构造二叉树

513.找树左下角的值

遍历二叉树,并记录当前的深度,如果深度大于最大深度,那么更新该节点,为了保证是最左的,我们规定顺序一定是先遍历左孩子再遍历右孩子

c 复制代码
class Solution {
public:
    int depth = 0;
    int result;
    void getV(TreeNode* root, int d){
        if(!root) return;
        if(!root->left && !root -> right){
            if(d > depth){depth = d; result = root -> val;}
        }
        getV(root -> left, d+1);
        getV(root -> right, d+1);
    }
    int findBottomLeftValue(TreeNode* root) {
        getV(root, 1);
        return result;

    }
};

112. 路径总和

还是对树进行一个dfs遍历,如果当前遍历的节点是叶子节点,就判断当前累计的sum是不是target

c 复制代码
class Solution {
public:
    bool find = false;
    void dfs(TreeNode* root, int sum,int targetSum){
        if(!root) return;
        if(sum  == targetSum && !root->left && !root->right){find = true; return;}
        
        if(root->left)dfs(root->left, sum + root -> left -> val, targetSum);
        if(root->right)dfs(root->right, sum + root -> right -> val, targetSum);
    }
    bool hasPathSum(TreeNode* root, int targetSum) {
        if(!root)return false;
        dfs(root, root -> val, targetSum);
        return find;
    }
};

106.从中序与后序遍历序列构造二叉树

这道题有意思,我们做题的时候构造二叉树都是先找后序序列的最后一个元素是根,然后根据这个根切割中序序列,然后再找中序序列前后两个分割序列,注意我们得到了中序分割的左右子树序列,那么我们可以这个左右子树序列的长度再对后序数组进行一个分割:

积累一个vector查询的方式:

c 复制代码
// 这个查询是[)区间左闭右开
auto y = find(inorder.begin()+in_left, inorder.begin() + in_right + 1, val);
int index = distance(inorder.begin(), y);

总代码如下:

c 复制代码
class Solution {
public:
    TreeNode* build(vector<int>& inorder, vector<int>& postorder, int in_left, int in_right, int po_left,int po_right){
        if(in_left > in_right || po_left > po_right) return nullptr;
        int val = postorder[po_right];
        auto y = find(inorder.begin()+in_left, inorder.begin() + in_right + 1, val);
        int index = distance(inorder.begin(), y);
        int left_length = index - in_left;
        int right_length = in_right - index;
        TreeNode* n = new TreeNode(postorder[po_right]);
        n -> left = build(inorder, postorder, in_left, in_left + left_length -1, po_left, po_left + left_length -1);
        n->right = build(inorder, postorder, in_right - right_length + 1 , in_right, po_right - 1 - right_length + 1, po_right - 1);
        return n;
    }
    TreeNode* buildTree(vector<int>& inorder, vector<int>& postorder) {
        if(inorder.size() == 0) return nullptr;
        return build(inorder, postorder, 0, inorder.size()-1, 0, postorder.size()-1);
    }
};
相关推荐
CoovallyAIHub8 分钟前
避开算力坑!无人机桥梁检测场景下YOLO模型选型指南
深度学习·算法·计算机视觉
YouQian77212 分钟前
问题 C: 字符串匹配
c语言·数据结构·算法
yanxing.D17 分钟前
408——数据结构(第二章 线性表)
数据结构·算法
艾莉丝努力练剑1 小时前
【LeetCode&数据结构】二叉树的应用(二)——二叉树的前序遍历问题、二叉树的中序遍历问题、二叉树的后序遍历问题详解
c语言·开发语言·数据结构·学习·算法·leetcode·链表
YuTaoShao1 小时前
【LeetCode 热题 100】51. N 皇后——回溯
java·算法·leetcode·职场和发展
1 小时前
3D碰撞检测系统 基于SAT算法+Burst优化(Unity)
算法·3d·unity·c#·游戏引擎·sat
Tony沈哲1 小时前
OpenCV 图像调色优化实录:基于图像金字塔的 RAW / HEIC 文件加载与调色实践
opencv·算法
我就是全世界2 小时前
Faiss中L2欧式距离与余弦相似度:究竟该如何选择?
算法·faiss
boyedu2 小时前
比特币运行机制全解析:区块链、共识算法与数字黄金的未来挑战
算法·区块链·共识算法·数字货币·加密货币
KarrySmile2 小时前
Day04–链表–24. 两两交换链表中的节点,19. 删除链表的倒数第 N 个结点,面试题 02.07. 链表相交,142. 环形链表 II
算法·链表·面试·双指针法·虚拟头结点·环形链表