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

【二叉树】最长同值路径

题目描述

给定一个二叉树的 root ,返回 最长的路径的长度 ,这个路径中的 每个节点具有相同值 。 这条路径可以经过也可以不经过根节点。

两个节点之间的路径长度 由它们之间的边数表示。

示例 1:

输入:root = [5,4,5,1,1,null,5]
输出:2

解题思路

这道题我想是用DFS解决,但是做了一会儿发现没有想清楚递归公式,最终还是查看了其他人的解法。

整个递归思路如下:

  • 找到(左子树+当前节点)的长度,设置为countLeft;
  • 找到(右子树+当前节点)的长度,设置为countRight;
  • max = Math.max(max, countLeft+countRight);
  • 返回Math.max(countLeft, countRight).

图示如下:


第一阶段

拆分成左子树:

 那么左子树中没有一条边上的2个节点相等,返回0,max=0

右子树:

 那么右子树中有一条边上的2个节点相等,返回1,max=1


第二阶段

根节点5,同左子树的根节点4比较,发现不相等,countLeft=0;

根节点5,同右子树的根节点5比较,发现相等,由于右子树已经返回1,则countRight=2;

最终计算max = Math.max(max, countLeft+countRight) = 2;  


具体代码实现如下:


import org.example.TreeNode;

class Solution {

    int max = 0;

    public int longestUnivaluePath(TreeNode root) {
        dfs(root);
        return max;
    }

    private int dfs(TreeNode root) {

        if (root != null) {

            int left = dfs(root.left);
            int right = dfs(root.right);


            int countLeft = 0;
            if (root.left != null && root.left.val == root.val) {
                countLeft = left + 1;
            }
            int countRight = 0;
            if (root.right != null && root.right.val == root.val) {
                countRight = right + 1;
            }
            max = Math.max(max, countLeft + countRight);

            return Math.max(countLeft, countRight);

        } else {
            return 0;
        }
    }


    public static void main(String[] args) {
        TreeNode root = new TreeNode(4);
        root.left = new TreeNode(4);
        root.right = new TreeNode(4);
        root.left.left = new TreeNode(4);
        root.right.left = new TreeNode(4);

        Solution solution = new Solution();
        System.out.println(solution.longestUnivaluePath(root));
    }
}

 总结

这道题是中等难度,这道题使用dfs做是很高效的,代码复杂度也不高,主要困难点是找到规律能通过左右子树来计算满足条件的边数量。如果有更加高效、简洁的代码实现欢迎回复。

 

相关文章:

  • 使用缓冲区提高并发
  • Windows10环境下Python 开发环境搭建
  • JavaEE TCP协议
  • 51单片机DS18B20温度报警器proteus仿真设计_可调上下限
  • SSRF漏洞
  • 猿创征文|平凡的应届生四年学习之路
  • mysql8忘记密码如何重置(禅道的mysqlzt服务和mysql服务冲突)
  • Nginx 配置 SSL(HTTPS)
  • 用css实现简单的动画——“奔跑的小子”(有知识梳理和图片)
  • macbook m1芯片 实现vscode下debug(解决无法读入的问题)
  • 前端:下载文件(多种方法)
  • 猿创征文|【JavaSE】 Collection集合全家桶
  • 【Coppeliasim+Add-on】附加组件-喷涂路径自动生成及喷涂仿真
  • 简易下载并使用Jupyter(Anaconda)
  • 北京大学肖臻老师《区块链技术与应用》公开课笔记:以太坊(四):The DAO、反思、美链、总结
  • 【vuex入门系列02】mutation接收单个参数和多个参数
  • 2018天猫双11|这就是阿里云!不止有新技术,更有温暖的社会力量
  • css布局,左右固定中间自适应实现
  • ESLint简单操作
  • HashMap ConcurrentHashMap
  • Idea+maven+scala构建包并在spark on yarn 运行
  • JS基础之数据类型、对象、原型、原型链、继承
  • python_bomb----数据类型总结
  • React-Native - 收藏集 - 掘金
  • Terraform入门 - 3. 变更基础设施
  • Three.js 再探 - 写一个跳一跳极简版游戏
  • Vue 动态创建 component
  • Yeoman_Bower_Grunt
  • 近期前端发展计划
  • 利用DataURL技术在网页上显示图片
  • 聊聊flink的BlobWriter
  • 全栈开发——Linux
  • 数据可视化之 Sankey 桑基图的实现
  • 算法之不定期更新(一)(2018-04-12)
  • 详解NodeJs流之一
  • 一道闭包题引发的思考
  • 掌握面试——弹出框的实现(一道题中包含布局/js设计模式)
  • 走向全栈之MongoDB的使用
  • AI算硅基生命吗,为什么?
  • C# - 为值类型重定义相等性
  • 阿里云ACE认证学习知识点梳理
  • #ubuntu# #git# repository git config --global --add safe.directory
  • $.extend({},旧的,新的);合并对象,后面的覆盖前面的
  • $con= MySQL有关填空题_2015年计算机二级考试《MySQL》提高练习题(10)
  • (arch)linux 转换文件编码格式
  • (done) NLP “bag-of-words“ 方法 (带有二元分类和多元分类两个例子)词袋模型、BoW
  • (草履虫都可以看懂的)PyQt子窗口向主窗口传递参数,主窗口接收子窗口信号、参数。
  • (原創) 如何優化ThinkPad X61開機速度? (NB) (ThinkPad) (X61) (OS) (Windows)
  • **PyTorch月学习计划 - 第一周;第6-7天: 自动梯度(Autograd)**
  • .net mvc 获取url中controller和action
  • .NET 设计一套高性能的弱事件机制
  • .NET/C# 编译期能确定的字符串会在字符串暂存池中不会被 GC 垃圾回收掉
  • .netcore 6.0/7.0项目迁移至.netcore 8.0 注意事项
  • .NETCORE 开发登录接口MFA谷歌多因子身份验证
  • .net连接MySQL的方法