编程之美读书笔记_3.8 求二叉树中节点的最大距离
来源:互联网 发布:淘宝卖家如何设置套餐 编辑:程序博客网 时间:2024/04/30 23:51
3.8 求二叉树中节点的最大距离
实际上就是求树的直径。树的任意两个点必然分别在某个节点的左子树部分和右子树部分(假设两个子树均包含该节点,这样对相邻的两个点,该结论也成立)。因此,“计算树的直径”,等同于“计算每个节点的左子树和右子树的高度和,取最大值 ”。
不少人会将该问题分解成“具有最大距离两点间的路径是否经过根节点”两个子问题,然后对这两个子问题求解并判断。但实际上,这两点必然在以某个节点 A 为根的子树上,它们间的路径必然经过该子树的根节点 A 。因而,以任意一个节点为根的子树,计算出经过该子树根节点的最大距离,则所有最大距离的最大值就是所要求的最大距离。而经过一个树的根节点的最大距离 = 左子树的高度 + 右子树的高度 +2 (假设空节点的高度为 -1 ),因而可以用一个全局变量 max_d 保存最大距离,采用深度优先遍历,每遍历一个节点,计算出左右子树的高度,计算出其高度,并将经过该节点的最大距离值与 max_d 值比较,并更新 max_d ,当遍历完所有节点时, max_d 就是所求的最大距离。
具体测试例子
- 编程之美读书笔记_3.8 求二叉树中节点的最大距离
- 编程之美读书笔记_3.8 求二叉树中节点的最大距离
- 编程之美读书笔记_3.8 求二叉树中节点的最大距离
- 编程之美读书笔记_3.8 求二叉树中节点的最大距离 和 3.10分层遍历二叉树 相关代码
- 读书笔记之编程之美 - 3.8 求二叉树中节点的最大距离
- 《编程之美》读书笔记12: 3.8 求二叉树中节点的最大距离
- 编程之美读书笔记-求二叉树中节点的最大距离
- [编程之美] PSet3.8 求二叉树中节点的最大距离
- 编程之美 - 求二叉树节点的最大距离
- 编程之美 3.8 求二叉树中节点的最大距离 3.9 重建二叉树
- 编程之美之求二叉树中节点的最大距离
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法(转)
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- Visual Studio开发工具(5):VS2010 精美壁纸,总有一款适合你!
- 核二数据库命名规则
- 编程之美读书笔记_4.5_磁带文件存放优化
- 编程之美读书笔记_4.4_是否在三角形内
- 编程之美读书笔记_4.1_金刚坐飞机问题
- 编程之美读书笔记_3.8 求二叉树中节点的最大距离
- 编程之美读书笔记_3.3_计算字符串的相似度
- 编程之美读书笔记_杂项
- 今日总结
- 用于构建 RESTful Web 服务的多层架构
- oracle体系结构
- windbg dump
- 集合
- JAVA与设计模式--之STRATEGY策略模式