一.题目要求
给你一棵二叉树的根节点,返回该树的 直径 。
二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。
两节点之间路径的 长度 由它们之间边数表示。
二.题目难度
简单
三.输入样例
示例 1:
输入:root = [1,2,3,4,5]
输出:3
解释:3 ,取路径 [4,2,1,3] 或 [5,2,1,3] 的长度。
示例 2:
输入:root = [1,2]
输出:1
提示:
树中节点数目在范围 [ 1 , 1 0 4 ] [1, 10^4] [1,104]内
-100 <= Node.val <= 100
四.解题思路
接了个后端开发一周没刷力扣脑子坏了,想复杂了。
设个全局变量,递归求深度的时候加判断若从该结点左子树到右子树长度大于目前长度则更新,遍历完所有情况最后就是最长的。
五.代码实现
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode() : val(0), left(nullptr), right(nullptr) {}
* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
* };
*/
class Solution {
public:
int diameterOfBinaryTree(TreeNode* root) {
deepTree(root);
return mmax;
}
int deepTree(TreeNode * root) {
if(root == nullptr)
return 0;
int leftLen = deepTree(root->left);
int rightLen = deepTree(root->right);
mmax = mmax < leftLen + rightLen ? leftLen + rightLen : mmax;
return leftLen > rightLen ? leftLen + 1 : rightLen + 1;
}
private:
int mmax = 0;
};
六.题目总结
一日不力扣一日没长进