领扣LintCode算法问题答案-1085. 最长的单一路径
发布日期:2021-06-30 17:09:49
浏览次数:4
分类:技术文章
本文共 2313 字,大约阅读时间需要 7 分钟。
领扣LintCode算法问题答案-1085. 最长的单一路径
目录
1085. 最长的单一路径
描述
给定一颗二叉树,找到路径中每个节点具有相同值的最长路径的长度。 此路径可能会也可能不会通过根节点。
- 两个节点之间的路径长度由它们之间的边数表示。
- 给定的二叉树不超过10000个节点。 树的高度不超过1000。
样例 1:
输入: 5 / \ 4 5 / \ \ 1 1 5输出:2
样例 2:
输入: 1 / \ 4 5 / \ \ 4 4 5输出:2
题解
/** * Definition of TreeNode: * public class TreeNode { * public int val; * public TreeNode left, right; * public TreeNode(int val) { * this.val = val; * this.left = this.right = null; * } * } */public class Solution { /** * @param root: * @return: the length of the longest path where each node in the path has the same value */ public int longestUnivaluePath(TreeNode root) { // Write your code here PointermaxValue = new Pointer<>(0); longestUnivaluePath(root, maxValue); return maxValue.v; } private int longestUnivaluePath(TreeNode root, Pointer maxValue) { if (root == null || (root.left == null && root.right == null)) { return 0; } int leftCount = longestUnivaluePath(root.left, maxValue); int rightCount = longestUnivaluePath(root.right, maxValue); if (root.left != null && root.left.val == root.val) { leftCount = leftCount + 1; } else { leftCount = 0; } if (root.right != null && root.right.val == root.val) { rightCount = rightCount + 1; } else { rightCount = 0; } int rootCount = 0; if (root.left != null && root.right != null) { rootCount = leftCount + rightCount; } maxValue.v = max(maxValue.v, leftCount, rightCount, rootCount); return max(leftCount, rightCount); } private int max(int...nums) { int ret = nums[0]; for (int num : nums) { if (num > ret) { ret = num; } } return ret; } class Pointer { private T v; public Pointer(T v) { this.v = v; } }}
鸣谢
非常感谢你愿意花时间阅读本文章,本人水平有限,如果有什么说的不对的地方,请指正。
欢迎各位留言讨论,希望小伙伴们都能每天进步一点点。
转载地址:https://le-yi.blog.csdn.net/article/details/108809405 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
路过,博主的博客真漂亮。。
[***.116.15.85]2024年04月12日 23时31分24秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
数据库系列篇mysql8-分库分表中间件mycat(WINDOWS环境)
2019-04-30
用户权限设计-基于RBAC模型
2019-04-30
微服务springcloud2系列篇-网关GATEWAY跨域问题
2019-04-30
Java并发以及多线程基础
2019-04-30
软件质量的8个特性
2019-04-30
应届渣渣前端的艰难求职之路
2019-04-30
2021年不可错过的17种JS优化技巧(一)
2019-04-30
2021年不可错过的17种JS优化技巧(二)
2019-04-30
月薪15~20k的前端面试问什么?
2019-04-30
一文学会使用Vue3
2019-04-30
我是如何看Vue源码的
2019-04-30
在 Vue 中用 Axios 异步请求API
2019-04-30
LVM逻辑卷------基础命令详解(三分钟入门)
2019-04-30
LVM逻辑卷------详细操作过程(三分钟上手)
2019-04-30
mysql——介绍及安装与基本用法
2019-04-30
MySQL数据库之索引
2019-04-30
MYSQL——事务操作+视图+存储引擎
2019-04-30
Mysql——完全备份+增量备份+备份恢复
2019-04-30
MySQL进阶查询(SELECT 语句高级用法)
2019-04-30