编程之美读书笔记_3.8 求二叉树中节点的最大距离

本文介绍了一种计算二叉树中节点间最大距离(即树的直径)的有效算法。通过深度优先搜索,递归地计算每个节点的左右子树高度,并利用这些信息找出整棵树的最大距离。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 原文链接:http://blog.youkuaiyun.com/flyinghearts/archive/2010/05/19/5605995.aspx

3.8 求二叉树中节点的最大距离

实际上就是求树的直径。树的任意两个点必然分别在某个节点的左子树部分和右子树部分(假设两个子树均包含该节点,这样对相邻的两个点,该结论也成立)。因此,“计算树的直径”,等同于“计算每个节点的左子树和右子树的高度和,取最大值 ”。

不少人会将该问题分解成“具有最大距离两点间的路径是否经过根节点”两个子问题,然后对这两个子问题求解并判断。但实际上,这两点必然在以某个节点 A 为根的子树上,它们间的路径必然经过该子树的根节点 A 。因而,以任意一个节点为根的子树,计算出经过该子树根节点的最大距离,则所有最大距离的最大值就是所要求的最大距离。而经过一个树的根节点的最大距离 = 左子树的高度 + 右子树的高度 +2 (假设空节点的高度为 -1 ),因而可以用一个全局变量 max_d 保存最大距离,采用深度优先遍历,每遍历一个节点,计算出左右子树的高度,计算出其高度,并将经过该节点的最大距离值与 max_d 值比较,并更新 max_d ,当遍历完所有节点时, max_d 就是所求的最大距离。

 

 

  1. struct Node{  
  2.   Node *left;  
  3.   Node *right;  
  4.   //data  
  5. };  
  6.   
  7. int tree_height(Node* root, int& max_d)  
  8. {  
  9.   //每碰到一个子节点,高度自增1,可以设空节点高度为-1,  
  10.   //避免计算高度时对空节点的判断。  
  11.   if (root==NULL) return -1;  
  12.   int a = tree_height(root->left, max_d) + 1;     
  13.   int b = tree_height(root->right, max_d) + 1;   
  14.   int c = a+b;  
  15.   if (max_d < c) max_d = c;  
  16.   return  a>b ? a : b;  
  17. }  
  18.   
  19. int tree_diameter(Node* root)  
  20. {  
  21.   int max_d=0;  
  22.   tree_height(root, max_d);  
  23.   return max_d;  
  24. }  
   

 

 

具体测试例子

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值