/**
* Definition for a binary tree node.
* public class TreeNode {
* public int val;
* public TreeNode left;
* public TreeNode right;
* public TreeNode(int x) { val = x; }
* }
*/
public class Solution
{
Stack<TreeNode> S = new Stack<TreeNode>();//记录访问过的节点 Dictionary<TreeNode, List<TreeNode>> dic = new Dictionary<TreeNode, List<TreeNode>>(); private void postTree(TreeNode node)
{
if (node != null)
{
S.Push(node);
if (node.left != null)
{
postTree(node.left);
}
if (node.right != null)
{
postTree(node.right);
} if (node.left == null && node.right == null)
{
var nodelist = S.ToList();
nodelist.Reverse(); if (!dic.ContainsKey(node))
{
dic.Add(node, nodelist);
}
}
S.Pop();
}
} public int DiameterOfBinaryTree(TreeNode root)
{
postTree(root); var maxDiameter = ; foreach (var d in dic)
{
foreach (var d2 in dic)
{
if (d.Key == d2.Key)
{
var diameter = d2.Value.Count - ;
maxDiameter = Math.Max(maxDiameter, diameter);
}
else
{
//第一种情况:计算叶子节点到根节点的直径
var depth = d2.Value.Count - ; var c1 = d.Value.Count;
var c2 = d2.Value.Count;
var diameter = ; if (c1 < c2)
{
for (int i = ; i < c1; i++)
{
if (d.Value[i] != d2.Value[i])
{
diameter = c1 - i + c2 - i;
break;
}
}
}
else
{
for (int i = ; i < c2; i++)
{
if (d.Value[i] != d2.Value[i])
{
diameter = c1 - i + c2 - i;
break;
}
}
} //var IncCount = d.Value.Intersect<TreeNode>(d2.Value).Count();
//var diameter = (c1 - IncCount) + (c2 - IncCount); diameter = Math.Max(diameter, depth);
maxDiameter = Math.Max(maxDiameter, diameter);
}
}
}
return maxDiameter;
}
}

https://leetcode.com/problems/diameter-of-binary-tree/#/description

补充一种递归的方式,使用python实现:

思路是每次递归判断,以当前节点为根节点是否能达到最大,见第14行。

而每次递归向上返回的是当前节点的左右子树的高度的更大的一个,加上当前节点(+1)的高度,见第15行。

 class Solution:
def __init__(self):
self.maxnum = #隐含的前提,最大的距离应该是两个叶子节点的距离
#本身这个函数是返回,当前节点到其所有叶子节点的最大深度
def getLength(self,root):
if root != None:
#左子树的最大深度
left = self.getLength(root.left)
#右子树的最大深度
right = self.getLength(root.right)
#在返回之前,更新maxnum
self.maxnum = max(self.maxnum,left+right)
return + max(left,right)
return def diameterOfBinaryTree(self, root: 'TreeNode') -> 'int':
self.getLength(root)
return self.maxnum

这道题目与leetcode104 二叉树的最大深度,思想是一样的,可以说是104题的升级版。

leetcode543的更多相关文章

  1. [Swift]LeetCode543. 二叉树的直径 | Diameter of Binary Tree

    Given a binary tree, you need to compute the length of the diameter of the tree. The diameter of a b ...

  2. LeetCode543. Diameter of Binary Tree

    Description Given a binary tree, you need to compute the length of the diameter of the tree. The dia ...

  3. Leetcode543.Diameter of Binary Tree二叉树的直径

    给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树 1 / \ 2    3 / \ 4  5 返回 3, 它 ...

  4. LeetCode543.二叉树的直径

    题目 1 class Solution { 2 public: 3 int minimum = INT_MIN; 4 vector<int>res; 5 int diameterOfBin ...

  5. LeetCode树专题

    LeetCode树专题 98. 验证二叉搜索树 二叉搜索树,每个结点的值都有一个范围 /** * Definition for a binary tree node. * struct TreeNod ...

随机推荐

  1. 数据库编程加入transaction

    TransManager tm = new TransManager(); tm.begin();//开启事物 try { //sql执行代码 // // tm.commit();//更改完sql之后 ...

  2. My First Linux Module

    My First Linux Module Today, I successfully build my first linux hello module. First of all add a di ...

  3. 团队项目(MVP------新能源无线充电管理网站)(个人任务3)

    现在我们组的项目已经完成了,之前做的欢迎界面已经废弃掉了,于是我重新制作了一个欢迎界面,主要是分为了团队介绍,充电商品的介绍,现在充电新闻的发展,解决方案,成功案例.其中产品里面又有两个商品的售卖页, ...

  4. 网站文档模式总是以Quirks文档模式解析网站

    <meta name="renderer" content="webkit"/> <meta http-equiv="X-UA-Co ...

  5. 【leetcode】437. Path Sum III

    problem 437. Path Sum III 参考 1. Leetcode_437. Path Sum III; 完

  6. JAVA常用设计模式(一、抽象工厂模式)

    抽象工厂模式 抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他工厂.该超级工厂又称为其他工厂的工厂.这种类型的设计模式属于创建型模式,它提供了一种创建对象的最 ...

  7. 【EMV L2】SDA静态数据认证处理流程

    [静态数据认证] 静态数据认证处理过程中,卡片没有执行任何处理,终端执行的处理流程:1.认证中心公钥的获取终端使用卡片上的认证中心公钥索引(PKI)[TAG:8F,Certification Auth ...

  8. 2018-2019-2 20165212《网络对抗技术》Exp2 后门原理与实践

    2018-2019-2 20165212<网络对抗技术>Exp2 后门原理与实践 1.实验内容 (1)使用netcat获取主机操作Shell,cron启动 (2)使用socat获取主机操作 ...

  9. 学习笔记TF043:TF.Learn 机器学习Estimator、DataFrame、监督器Monitors

    线性.逻辑回归.input_fn()建立简单两个特征列数据,用特证列API建立特征列.特征列传入LinearClassifier建立逻辑回归分类器,fit().evaluate()函数,get_var ...

  10. Vue列表组件与弹窗组件示例

    列表组件 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <me ...