博客
关于我
给定一个二叉树, 找到该树中两个指定节点的最近公共祖先
阅读量: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学习总结(51)——Linux主机Mysql数据库自动备份
查看>>
Mysql学习总结(52)——最全面的MySQL 索引详解
查看>>
Mysql学习总结(53)——使用MySql开发的Java开发者规范
查看>>
Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
查看>>
Mysql学习总结(55)——MySQL 语句大全再温习
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>