编程之美之求二叉树中节点的最大距离
来源:互联网 发布:淘宝客返利网 赚钱 编辑:程序博客网 时间:2024/05/18 02:05
题目:如果我们把二叉树看成一个图,父子节点之间的连线看成是双向的,我们姑且定义"距离"为两节点之间边的个数。写一个程序求一棵二叉树中相距最远的两个节点之间的距离。
分析:树上分析的很清楚,计算一个二叉树的最大距离有两个情况:1、 路径经过左子树的最深节点,通过根节点,再到右子树的最深节点。
2、 路径不穿过根节点,而是左子树或右子树的最大距离路径,取其大者。
但是书上的代码使用了额外的节点字段,这里给出我的代码,思路是一样的:
struct BinaryTree{int value;BinaryTree* left;BinaryTree* right;BinaryTree(int x):value(x),left(NULL),right(NULL){}};void findMaxLength(BinaryTree* root,int& depth,int& maxLength){if(root == NULL){depth = -1;maxLength = 0;return;}int ldepth,rdepth,lmaxLength,rmaxLength;findMaxLength(root -> left,ldepth,lmaxLength);findMaxLength(root -> right,rdepth,rmaxLength);depth = max(ldepth,rdepth)+1;maxLength = max(lmaxLength,rmaxLength);maxLength = max(maxLength,ldepth+rdepth+2);}int findMaxLength(BinaryTree* root){int depth=0,maxLength=0;findMaxLength(root,depth,maxLength);return maxLength;}
2 1
- 编程之美 - 求二叉树节点的最大距离
- 编程之美 3.8 求二叉树中节点的最大距离 3.9 重建二叉树
- 读书笔记之编程之美 - 3.8 求二叉树中节点的最大距离
- 编程之美之求二叉树中节点的最大距离
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法(转)
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 编程之美: 求二叉树中节点的最大距离》的好解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- 《编程之美: 求二叉树中节点的最大距离》的另一个解法
- PHP中递归函数的一个常见逻辑问题
- C/C++语言 static关键字的用法
- 编程之美之队列中取最大值操作
- java读取xls
- 八卦与ASCII码
- 编程之美之求二叉树中节点的最大距离
- C++高精度模板
- 关于KeyPress事件只能输入数字小数的问题
- 字符串类型的数字从小到大排序方法
- android--内存泄漏的原因及相关分析
- Cassandra 的数据存储结构
- Ruby 判断字符串是否对称
- 我母亲是个非常节俭的人
- SSH框架(一) Web开发中获取Spring的ApplicationContext的三种方式