您的位置:首页 > 新闻 > 资讯 > 朋友圈推广文案_电商平台投诉_谷歌优化推广_seo关键词智能排名

朋友圈推广文案_电商平台投诉_谷歌优化推广_seo关键词智能排名

2025/1/5 12:09:40 来源:https://blog.csdn.net/2201_75413354/article/details/142380002  浏览:    关键词:朋友圈推广文案_电商平台投诉_谷歌优化推广_seo关键词智能排名
朋友圈推广文案_电商平台投诉_谷歌优化推广_seo关键词智能排名

目录

一、题目描述

二、整体思路

三、代码


一、题目描述

原题地址

二、整体思路

        取一个结点的最大直径就是取一个结点的左子树最大深度+右子树最大深度之和,因此可以定义一个递归函数,作用是取一个结点的最大直径。这个函数中还实现了求左子树最大深度/右子树最大深度的功能。

        容易搞不明白的是边界条件。这里我定义一个结点的左子树和右子树都为空时,该节点深度=1。

        因此,一个结点的直径=左子树根节点深度和+子树根节点深度。就不用像官方题解那样又加一又减一了。

三、代码

/*** 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 {int maxr=0;public int diameterOfBinaryTree(TreeNode root) {if(root.left==null && root.right==null){return 0;}go(root);return maxr;}public int go(TreeNode root){if(root==null){return 0;}int l=go(root.left);int r=go(root.right);maxr=Math.max(l+r,maxr);return Math.max(l,r)+1;}
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com