博客
关于我
C++实现二叉树的最近公共祖先
阅读量:683 次
发布时间:2019-03-17

本文共 827 字,大约阅读时间需要 2 分钟。

一、问题描述

找出两个给定树节点的最低公共祖先(即最近公共祖先)。首先明确,什么是“祖先”?在树结构中,任一节点的祖先是该节点到根节点的所有后续节点。最近公共祖先则是两个节点所在路径的最后一个相同的节点。

二、解决方案

解决此问题,采用后序遍历方法。后续遍历可以帮助从左右子树中依次探索,逐渐缩小范围,找到最近的公共祖先。

解决思路:

  • 分析近似情况,明确底部情况。
  • 采用后序节点攻击,共用父节点。
  • 递归式逐步找到最近公共祖先节点。
  • 代码实现:

    Solution::lowestCommonAncestor(TreeNode* root, TreeNode* p,    TreeNode* q) {    if (root == NULL || root == p || root == q)        return root;    TreeNode* left = lowestCommonAncestor(root->left, p, q);    TreeNode* right = lowestCommonAncestor(root->right, p, q);    if (left == NULL)        return right;    if (right == NULL)        return left;    return root;}

    三、运行结果

    如图所示,代码逻辑正确,能够符合预期运行结果。

    四、大佬解析

    代码采用递归策略,通过后序遍历找到最近公共祖先。从根节点开始,若当前节点是p或q,直接返回。如果左、右子树找到符合条件的节点,则返回较低的那一侧。若两边同时找到,说明当前节点即为最近公共祖先。这种方法保证了在树结构中准确地找到两节点的最近相连点。

    这个方案通过递归实现,保持了树的纯度,逻辑简单易懂。若对时间复杂度有要求,可能需优化,但本题递归实现可满足需求。代码注释清晰,易于理解,保证可维护性。

    转载地址:http://jthhz.baihongyu.com/

    你可能感兴趣的文章
    06二维数组
    查看>>
    Springboot 初學習
    查看>>
    如何用华为位置服务实现搜索位置返回父子节点信息
    查看>>
    2020年云南省专升本 - 「计算机」专业各院校招生计划
    查看>>
    同一个实例注册到两个eureka上面
    查看>>
    【数据库】实验二~六
    查看>>
    uni-app的请求数据的封装
    查看>>
    C++容器笔记
    查看>>
    Android 四大组件、五大存储、六大布局总结
    查看>>
    【VRP问题】基于模拟退火改进遗传算法求解带时间窗含充电站的车辆路径规划问题EVRPTW
    查看>>
    【图像识别】基于模板匹配实现手写数字识别
    查看>>
    【语音去噪】最小二乘法(LMS)自适应滤波器matlab源码
    查看>>
    【边缘检测】基于CNN的灰度图像边缘提取matlab源码
    查看>>
    打工族有房有车,原来是这么实现的
    查看>>
    算法 顺序查找/折半查找/冒泡排序/选择排序(待改)
    查看>>
    华为1+X网络系统建设与运维(中级)——4.1 VLAN技术原理
    查看>>
    HDFS的学习积累
    查看>>
    Rancher入门到精通-2.0 systemctl 启动服务Connection timed out
    查看>>
    Rancher从入门到精通-2.0 配置gitlab代码库 404页面 原因有点扯
    查看>>
    ProgresSql 连接 ssl off 错误
    查看>>