Leetcode会员尊享100题:270.最接近的二叉树值

给你二叉搜索树的根节点 root 和一个目标值 target ,请在该二叉搜索树中找到最接近目标值 target 的数值。如果有多个答案,返回最小的那个。

示例 1:

复制代码
输入:root = [4,2,5,1,3], target = 3.714286
输出:4

示例 2:

复制代码
输入:root = [1], target = 4.428571
输出:1

提示:

  • 树中节点的数目在范围 [1, 104]
  • 0 <= Node.val <= 109
  • -109 <= target <= 109

直接上代码:

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public int closestValue(TreeNode root, double target) {
        Info info = getInfo(root, target);
        return info.value;
    }

    public Info getInfo(TreeNode root, double target) {
        if(root == null) {
            return new Info(Integer.MAX_VALUE, Integer.MAX_VALUE);
        }
        if(root.left == null && root.right == null) {
            return new Info(root.val, Math.abs(root.val - target));
        }
        /**拿到左右子树的信息 */
        Info leftInfo = getInfo(root.left, target);
        Info rightInfo = getInfo(root.right, target);
        /**当前的最小差是左右树的最小差以及跟节点和target的差的最小值 */
        double distance = Math.min(Math.abs(root.val - target), Math.min(leftInfo.distance, rightInfo.distance));
        int value = distance == leftInfo.distance? leftInfo.value : distance == rightInfo.distance? rightInfo.value : root.val;
        /**有可能有重复的值,需要判断取最小那个 */
        if(distance == leftInfo.distance) {
            value = Math.min(value, leftInfo.value);
        }
        if(distance == rightInfo.distance) {
            value = Math.min(value, rightInfo.value);
        }
        if(distance == Math.abs(root.val - target)) {
            value = Math.min(value, root.val);
        }
        /**返回当前树的信息 */
        return new Info(value, distance);
    }
}

class Info {
    int value;
    double distance;
    public Info(int value, double distance) {
        this.value = value;
        this.distance = distance;
    }
}

看不懂的请私信或者留言,二叉树的所有问题,我倾向于使用二叉树的递归套路,这个题其实可以用DFS,我懒得用

相关推荐
小O的算法实验室1 天前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
‎ദ്ദിᵔ.˛.ᵔ₎1 天前
LIST 的相关知识
数据结构·list
M--Y1 天前
Redis常用数据类型
数据结构·数据库·redis
郭涤生1 天前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿1 天前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数