博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
543 Diameter of Binary Tree 二叉树的直径
阅读量:5102 次
发布时间:2019-06-13

本文共 1476 字,大约阅读时间需要 4 分钟。

给定一棵二叉树,你需要计算它的直径长度。一棵二叉树的直径长度是任意两个结点路径长度中的最大值。这条路径可能穿过根结点。

示例 :
给定二叉树
          1
         / \
        2   3
       / \     
      4   5    
返回 3, 它的长度是路径 [4,2,1,3] 或者 [5,2,1,3]。
注意:两结点之间的路径长度是以它们之间边的数目表示。
详见:https://leetcode.com/problems/diameter-of-binary-tree/description/

C++:

方法一:

class Solution {public:    int diameterOfBinaryTree(TreeNode* root)     {        int res = 0;        maxDepth(root, res);        return res;    }    int maxDepth(TreeNode* node, int& res)    {        if (!node)        {            return 0;        }        int left = maxDepth(node->left, res);        int right = maxDepth(node->right, res);        res = max(res, left + right);        return max(left, right) + 1;    }};

 方法二:

/** * Definition for a binary tree node. * struct TreeNode { *     int val; *     TreeNode *left; *     TreeNode *right; *     TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */class Solution {public:    int diameterOfBinaryTree(TreeNode* root) {        int res=0;        maxDepth(root,res);        return res;    }    int maxDepth(TreeNode* node,int &res)    {        if(!node)        {            return 0;        }        if(m.count(node))        {            return m[node];        }        int left=maxDepth(node->left,res);        int right=maxDepth(node->right,res);        res=max(res,left+right);        return m[node]=(max(left,right)+1);    }private:    unordered_map
m;};

 参考:http://www.cnblogs.com/grandyang/p/6607318.html

转载于:https://www.cnblogs.com/xidian2014/p/8921479.html

你可能感兴趣的文章
数据结构与算法(三)-线性表之静态链表
查看>>
mac下的mysql报错:ERROR 1045(28000)和ERROR 2002 (HY000)的解决办法
查看>>
快速幂
查看>>
改善C#公共程序类库质量的10种方法
查看>>
AIO 开始不定时的抛异常: java.io.IOException: 指定的网络名不再可用
查看>>
MyBaits动态sql语句
查看>>
HDU4405(期望DP)
查看>>
拉格朗日乘子法 那些年学过的高数
查看>>
vs code 的便捷使用
查看>>
Spring MVC @ResponseBody返回中文字符串乱码问题
查看>>
用户空间与内核空间,进程上下文与中断上下文[总结]
查看>>
JS 中的跨域请求
查看>>
JAVA开发环境搭建
查看>>
mysql基础语句
查看>>
Oracle中的rownum不能使用大于>的问题
查看>>
[Data Structure & Algorithm] 有向无环图的拓扑排序及关键路径
查看>>
cassandra vs mongo (1)存储引擎
查看>>
Visual Studio基于CMake配置opencv1.0.0、opencv2.2
查看>>
遍历Map对象
查看>>
MySQL索引背后的数据结构及算法原理
查看>>