计算二叉树中最远节点距离

计算二叉树中最远节点距离的问题可以通过遍历或递归解决。直接遍历方法时间复杂度高,为O(n^2)。优化方法是通过一次递归计算每个节点的深度和以该节点为根的子树最大距离,达到更高效的求解。
摘要由CSDN通过智能技术生成

二叉树最远节点距离:以根节点为轴左右子树最大深度之和与以各个子树的根节点为轴左右子树的最大深度之和的较大者。

思路一:解决这个问题最直接的方式就是遍历。对每个节点求深度,之后再与保存的最大深度maxdepth进行对比,但是时间复杂度为O(n^2),这是一种比较糟糕的时间复杂度。
思路二:针对思路一,重复了大量的遍历工作,对每一个节点求深度,对最深的节点遍历了2^n次,没有线索化的二叉树遍历,最常用的是递归的方法,因此我们可以仅通过一次递归可以得到节点的深度和以此节点为根的子树的最大距离。

#include<stdio.h>
#include<stdlib.h>
//创建二叉树,二叉树中输入0表示空节点
typedef struct TNode
{
    int data;
    struct TNode *lchild,*rchild;
 }TNode,*
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值