博客
关于我
给定一个二叉树, 找到该树中两个指定节点的最近公共祖先
阅读量: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 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>