124.二叉树中的最大路径和
package org.example; class Solution { /** * 最大路径和 */ private int maxPathSum Integer.MIN_VALUE; public int maxPathSum(TreeNode root) { maxPath(root); return maxPathSum; } /** * 计算经过 treeNode 结点的路径的最大路径和 * * param treeNode 结点 * return 经过 treeNode 结点的路径的最大路径和 */ private int maxPath(TreeNode treeNode) { if (treeNode null) { return 0; } // 左子树的最大路径和 int leftSum Math.max(0, maxPath(treeNode.left)); // 右子树的最大路径和 int rightSum Math.max(0, maxPath(treeNode.right)); // 更新最大路径和 maxPathSum Math.max(maxPathSum, treeNode.val leftSum rightSum); // 返回经过当前结点的路径的最大路径和 return treeNode.val Math.max(leftSum, rightSum); } }
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2521309.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!