博客
关于我
给定一个二叉树, 找到该树中两个指定节点的最近公共祖先
阅读量:546 次
发布时间:2019-03-08

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

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先

三种情况:

1)、如果左边为空,右边不为空,则右边的第一个节点就为公共祖先
2)、如果右边为空,左边不为空,则左边的第一个节点就为公共祖先
3)、如果左右都有,则root就为公共祖先

根据前序遍历的方式来写

第一步:定义p、q,判断是二叉树否为空

第二步:如果p或q为root,直接返回root;如果不是,分别在左子树,右子树查找p、q
第三步:查找分三种情况,若左右子树都不为空,且如果p或q为root,直接返回root
若左子树不为空,右子树为空,则共同祖先就在左子树上,返回左子树
若右子树不为空,左子树为空,则共同祖先就在右子树上,返回右子树

class Solution5 {    public TreeNode2 lowestCommonAncestor(TreeNode2 root, TreeNode2 p, TreeNode2 q) {        if(root==null){            return null;        }        if(root==p || root==q){          return root;        }        TreeNode2 leftTree=lowestCommonAncestor(root.left,p,q);        TreeNode2 rightTree=lowestCommonAncestor(root.right,p,q);        if(leftTree!=null && rightTree!=null){            return root;        }        if(leftTree !=null){            return leftTree;        }        if(rightTree !=null){            return rightTree;        }        return null;    }

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

你可能感兴趣的文章
mysql驱动、durid、mybatis之间的关系
查看>>
mysql驱动支持中文_mysql 驱动包-Go语言中文社区
查看>>
MySQL高可用切换_(5.9)mysql高可用系列——正常主从切换测试
查看>>
MYSQL高可用集群MHA架构
查看>>
MySQL高级-MySQL并发参数调整
查看>>
MySQL高级-MySQL查询缓存优化
查看>>
MySQL高级-SQL优化步骤
查看>>
MySQL高级-视图
查看>>
MySQL高级-触发器
查看>>
mysql高级查询~分页查询
查看>>
MySQL(2)DDL详解
查看>>
MySQL:MySQL执行一条SQL查询语句的执行过程
查看>>
Mysql:SQL性能分析
查看>>
mysql:SQL按时间查询方法总结
查看>>
MySQL:判断逗号分隔的字符串中是否包含某个字符串
查看>>
MySQL:某个ip连接mysql失败次数过多,导致ip锁定
查看>>
Mysql:避免重复的插入数据方法汇总
查看>>
n 叉树后序遍历转换为链表问题的深入探讨
查看>>
nacos config
查看>>
NacosClient客户端搭建,微服务注册进nacos
查看>>