leetcode543
/**
* 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的更多相关文章
- [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 ...
- LeetCode543. Diameter of Binary Tree
Description Given a binary tree, you need to compute the length of the diameter of the tree. The dia ...
- Leetcode543.Diameter of Binary Tree二叉树的直径
给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树 1 / \ 2 3 / \ 4 5 返回 3, 它 ...
- LeetCode543.二叉树的直径
题目 1 class Solution { 2 public: 3 int minimum = INT_MIN; 4 vector<int>res; 5 int diameterOfBin ...
- LeetCode树专题
LeetCode树专题 98. 验证二叉搜索树 二叉搜索树,每个结点的值都有一个范围 /** * Definition for a binary tree node. * struct TreeNod ...
随机推荐
- python基础09_字符串格式化
首先,使用%s 的方法. #!/usr/bin/env python # coding:utf-8 # 不用format方法,使用%s 和%d name = 'Tom' age = 100 msg = ...
- @MapperScan使用
@MapperScan:要扫描mapper类包的路径 还可以扫描多个包,如: @MapperScan({"com.kfit.demo","com.kfit.user&qu ...
- 数据库行转列、列转行,pivot透视多列
这就是典型的行转列问题. 首先说下最简单的思路 用union all select year,sum(m1) m1,sum(m2) m2,sum(m3) m3,sum(m4) m4 from ( s ...
- 自动化测试-2.seleniumIDE
一.安装步骤 1. 打开Firefox浏览器 2. 打开https://addons.mozilla.org/en-US/firefox/addon/selenium-ide/versions/,点击 ...
- api管理平台
安装和介绍 安装要求:(centos安装环境) nodejs(7.6+) mongodb(2.6|+) 安装get和编译的工具 yum -y install wget make gcc gcc-c++ ...
- ie8网页时调用特定的css文件
加上条件注释语句<!--[if IE 8]><link rel="".........................><![endif]--> ...
- Windows跨域远程连接防火墙设置
按照正常的防火墙的设置,发现跨域远程依然不行,后来进过排除法发现 还需要打开icmpv4所有的协议,才可以
- Windows下运行Linux命令
安装Gow软件,Gow-0.7.0.exe,这样就可以在Windows命令行运行Linux命令,比如通过scp把Windows下的文件拷贝到Linux下. 直接运行安装,不会生成任何客户端,直接使用W ...
- 公式推导:【BACF】
[BACF]: Kiani Galoogahi H, Fagg A, Lucey S. Learning Background-Aware Correlation Filters for Visual ...
- lavarel mongo 操作
本人使用环境 Ubuntu 18.04 LTS php7.2 lavarel5.5 mongodb的安装 mongodb 服务的安装 这个链接中有最全面最新的安装文档 https://docs ...