有向图最长路径算法_「算法」求二叉树的最长同值路径

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

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

示例 1:

输入:

42c6aa411c505a1cfa23f8ffacfbf9c7.png

输出:

2

示例 2:

输入:

778957c2c92bee4cddc8c113297d206e.png

输出:

2

注意: 给定的二叉树不超过10000个结点。 树的高度不超过1000。

解题方案:

采用递归的方法解决该问题。

思路

我们可以将任何路径(具有相同值的节点)看作是最多两个从其根延伸出的箭头。

具体地说,路径的根将是唯一节点,因此该节点的父节点不会出现在该路径中,而箭头将是根在该路径中只有一个子节点的路径。

然后,对于每个节点,我们想知道向左延伸的最长箭头和向右延伸的最长箭头是什么?我们可以用递归来解决这个问题。

算法

令 pathLength(node) 为从节点 node 延伸出的最长箭头的长度。如果 node.Left 存在且与节点 node 具有相同的值,则该值就会是 1 + pathLength(node.left)。在 node.right 存在的情况下也是一样。

当我们计算箭头长度时,候选答案将是该节点在两个方向上的箭头之和。我们将这些候选答案记录下来,并返回最佳答案。

int ans = 0;public int longestUnivaluePath(TreeNode root) {    pathLength(root);    return ans;}private int pathLength(TreeNode node) {    if (node == null) return 0;    int left = pathLength(node.left);    int right = pathLength(node.right);    int leftValue = (null != node.left && node.val == node.left.val) ? left + 1 : 0;    int rightValue = (null != node.right && node.val == node.right.val) ? right + 1 : 0;    ans = Math.max(ans, leftValue + rightValue);    return Math.max(leftValue, rightValue);}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值