首页 > 代码库 > [leetcode-543-Diameter of Binary Tree]
[leetcode-543-Diameter of Binary Tree]
Given a binary tree, you need to compute the length of the diameter of the tree.
The diameter of a binary tree is the length of the longest path between any two nodes in a tree.
This path may or may not pass through the root.
Example:
Given a binary tree
1
/ \
2 3
/ \
4 5
Return 3, which is the length of the path [4,2,1,3] or [5,2,1,3].
思路:
求二叉树的高度,左子树的高度加上右子树的高度就为最大的直径。
int height(TreeNode* root, int& diameter) { if (root == NULL) return 0; int left = height(root->left, diameter); int right = height(root->right, diameter); diameter = max(diameter, left + right); return 1 + max(left, right); } int diameterOfBinaryTree(TreeNode* root) { int diameter = 0; height(root, diameter); return diameter; }
参考:
https://discuss.leetcode.com/topic/83569/543-diameter-of-binary-tree-c-_recursive_with-brief-explanation
[leetcode-543-Diameter of Binary Tree]
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。