【结构之法】二叉树中节点的最大距离

本文探讨了如何找到二叉树中相距最远的两个节点,提出了优于《编程之美》中解法的新思路。通过考虑两种情况——路径经过根节点或不经过根节点——来计算最大距离,分别对应于左、右子树的最深节点的组合,以及左右子树最大距离的对比。最后,文章提到了解法的测试环节。
摘要由CSDN通过智能技术生成

前言:编程之美中的解法并不是最好的,所以这里给出大神的解法。

问题:

如果我们把二叉树看成一个图,父子节点之间的连线看成是双向的,我们姑且定义”距离”为两节点之间边的个数。写一个程序求一棵二叉树中相距最远的两个节点之间的距离。
这里写图片描述

思路

计算一个二叉树的最大距离有两个情况:

情况A: 路径经过左子树的最深节点,通过根节点,再到右子树的最深节点。
情况B: 路径不穿过根节点,而是左子树或右子树的最大距离路径,取其大者。
只需要计算这两个情况的路径距离,并取其大者,就是该二叉树的最大距离。

这里写图片描述

新的解法

#include <iostream>
using namespace std;

struct NODE
{
    NODE *pLeft;
    NODE *pRight;
};

struct RESULT
{
    int nMaxDistance;
    int nMaxDepth;
};

RESULT GetMaximumDistance(NODE* root)
{
    if (!root)
    {
        RESULT empty = { 0, -1 };   
        return empty;
    }

    RESULT lhs = GetMaximumDistance(root->pLeft);
    RESULT rhs = GetMaximumDistance(root->pRight);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值