dfs,LeetCode 1026. 节点与其祖先之间的最大差值

一、题目

1、题目描述

给定二叉树的根节点 root,找出存在于 不同 节点 A 和 B 之间的最大值 V,其中 V = |A.val - B.val|,且 A 是 B 的祖先。

(如果 A 的任何子节点之一为 B,或者 A 的任何子节点是 B 的祖先,那么我们认为 A 是 B 的祖先)

2、接口描述

python3
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def maxAncestorDiff(self, root: Optional[TreeNode]) -> int:
cpp
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    int maxAncestorDiff(TreeNode* root) {

    }
};

3、原题链接

1026. 节点与其祖先之间的最大差值


二、解题报告

1、思路分析

我们从根往下dfs,维护路径上的最大值ma最小值mi,当遇到空节点时,我们用ma - mi维护最大差值

2、复杂度

时间复杂度: O(n)空间复杂度:O(n),递归栈开销

3、代码详解

python3
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def maxAncestorDiff(self, root: Optional[TreeNode]) -> int:
        ret = 0
        def dfs(rt: Optional[TreeNode], mi: int, ma: int) -> None:
            if not rt:
                nonlocal ret
                ret = max(ret, ma - mi)
                return
            ma = max(ma, rt.val)
            mi = min(mi, rt.val)
            dfs(rt.left, mi, ma)
            dfs(rt.right, mi, ma)
        dfs(root, root.val, root.val)
        return ret
cpp
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    int maxAncestorDiff(TreeNode* root) {
        int ret = 0;
        function<void(TreeNode*, int, int)> dfs = [&](TreeNode* rt, int mi, int ma){
            if(!rt) {
                ret = max(ret, ma - mi);
                return;
            }
            
            dfs(rt->left, min(mi, rt->val), max(rt->val, ma));
            dfs(rt->right, min(mi, rt->val), max(rt->val, ma));
        };
        dfs(root, root->val, root->val);
        return ret;
    }
};

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-07 16:40:05       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-07 16:40:05       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-07 16:40:05       87 阅读
  4. Python语言-面向对象

    2024-04-07 16:40:05       96 阅读

热门阅读

  1. QT各种锁及线程同步应用

    2024-04-07 16:40:05       33 阅读
  2. C语言形参与实参

    2024-04-07 16:40:05       43 阅读
  3. Elasticsearch如何选择版本

    2024-04-07 16:40:05       37 阅读
  4. socket套接字函数

    2024-04-07 16:40:05       34 阅读
  5. ss命令

    2024-04-07 16:40:05       36 阅读
  6. video替换webRtc视频流

    2024-04-07 16:40:05       42 阅读
  7. vim编辑器基本使用教程

    2024-04-07 16:40:05       35 阅读
  8. 第五届信大超越杯团体赛部分题解

    2024-04-07 16:40:05       37 阅读
  9. 练习3-7 成绩转换

    2024-04-07 16:40:05       33 阅读
  10. 15届蓝桥备赛(5)

    2024-04-07 16:40:05       33 阅读
  11. 第十四届蓝桥杯省赛大学C组(C/C++)三国游戏

    2024-04-07 16:40:05       42 阅读