LeetCode //C - 1026. Maximum Difference Between Node and Ancestor

1026. Maximum Difference Between Node and Ancestor

Given the root of a binary tree, find the maximum value v for which there exist different nodes a and b where v = |a.val - b.val| and a is an ancestor of b.

A node a is an ancestor of b if either: any child of a is equal to b or any child of a is an ancestor of b.

Example 1:

Input: root = 8,3,10,1,6,null,14,null,null,4,7,13
Output: 7
Explanation: We have various ancestor-node differences, some of which are given below :

|8 - 3| = 5

|3 - 7| = 4

|8 - 1| = 7

|10 - 13| = 3

Among all possible differences, the maximum value of 7 is obtained by |8 - 1| = 7.

Example 2:

Input: root = 1,null,2,null,0,3
Output: 3

Constraints:
  • The number of nodes in the tree is in the range 2, 5000.
  • 0 < = N o d e . v a l < = 10 5 0 <= Node.val <= 10^5 0<=Node.val<=105

From: LeetCode

Link: 1026. Maximum Difference Between Node and Ancestor


Solution:

Ideas:

For each node, keep track of:

  • the minimum value seen on the path from the root to this node
  • the maximum value seen on the path from the root to this node

Then the maximum ancestor difference on that path is:

  • curMax - curMin

So during DFS:

  • update curMin and curMax with the current node value
  • continue to left and right children
  • when reaching NULL, return the difference for that path
Code:
c 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     struct TreeNode *left;
 *     struct TreeNode *right;
 * };
 */

static int max(int a, int b) {
    return a > b ? a : b;
}

static int min(int a, int b) {
    return a < b ? a : b;
}

static int dfs(struct TreeNode* node, int curMin, int curMax) {
    if (node == NULL) {
        return curMax - curMin;
    }

    curMin = min(curMin, node->val);
    curMax = max(curMax, node->val);

    int leftAns = dfs(node->left, curMin, curMax);
    int rightAns = dfs(node->right, curMin, curMax);

    return max(leftAns, rightAns);
}

int maxAncestorDiff(struct TreeNode* root) {
    return dfs(root, root->val, root->val);
}
相关推荐
NOVAnet20238 小时前
AI 全球化部署网络瓶颈:算法模型跨地域、跨云互联核心痛点解析
算法·ai·sd-wan·专线·跨区域
wuminyu8 小时前
Java锁机制之轻量级锁判断与尝试逻辑源码剖析
java·linux·c语言·jvm·c++
Misnearch8 小时前
1、数组/字符串
java·数据结构·算法
008爬虫实战录8 小时前
【数据结构】 树、二叉树、完全二叉树,先序遍历、中序遍历、后序遍历
数据结构·算法
小O的算法实验室8 小时前
2024年AST,基于费马点分组粒子群算法的复合型无人机统一路径规划
算法·无人机
AllData公司负责人9 小时前
大模型赋能AllData数据中台,系列升级|通过联合智谱大模型与BiSheng开源项目,建设企业大模型应用开发平台,支持知识库向量检索!
大数据·数据结构·数据库·算法·大模型·向量数据库·智谱ai
一个王同学9 小时前
从零到一 | CV转多模态大模型 | week12 | 整理 MiniLLaVA 工程与文档
人工智能·深度学习·算法·机器学习·计算机视觉
这料鬼有毒9 小时前
二刷hot100-78.子集
算法·leetcode·职场和发展
ZHW_AI课题组9 小时前
使用DBSCAN算法对纽约市 Airbnb 房源数据集进行聚类分析
算法