博客
关于我
给定一个二叉树, 找到该树中两个指定节点的最近公共祖先
阅读量: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/

你可能感兴趣的文章
Navicat 导入sql文件
查看>>
navicat 添加外键1215错误
查看>>
navicat 系列软件一点击菜单栏就闪退
查看>>
Navicat 设置时间默认值(当前最新时间)
查看>>
navicat 连接远程mysql
查看>>
navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
查看>>
Navicate for mysql 数据库设计-数据库分析
查看>>
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
ndk特定版本下载
查看>>
NDK编译错误expected specifier-qualifier-list before...
查看>>
Neat Stuff to Do in List Controls Using Custom Draw
查看>>
Necurs僵尸网络攻击美国金融机构 利用Trickbot银行木马窃取账户信息和欺诈
查看>>