Leetcode 236 二叉树的最近公共祖先

var pTrace [](*TreeNode)
var qTrace [](*TreeNode)
func getTrace(root, k *TreeNode, trace [](*TreeNode), flag bool){
    if root == nil || flag && len(pTrace) != 0 || !flag && len(qTrace) != 0{ // 这个方向找不到了
        return
    }
    if root.Val == k.Val{
        trace = append(trace, root)
        if flag {
            pTrace = trace
        }else{
            qTrace = trace
        }
        return
    }
    trace = append(trace, root)
    getTrace(root.Left, k, trace, flag)
    getTrace(root.Right, k, trace, flag)
}

func lowestCommonAncestor(root, p, q *TreeNode) *TreeNode {
     pTrace = []*TreeNode{}
     qTrace = []*TreeNode{}
     getTrace(root, p, [](*TreeNode){}, true)
     getTrace(root, q, [](*TreeNode){}, false)
     var i, j int
     for i < len(pTrace) && j < len(qTrace){
         if pTrace[i] != qTrace[j]{
             return pTrace[i-1]
         }
         i ++
         j ++
     }
     if i == len(pTrace){
         return pTrace[len(pTrace)-1]
     }else{
         return qTrace[len(qTrace)-1]
     }
}

分别找到两个节点的所有祖先节点,也就得到两个节点list,两个list分别从前往后遍历,直到遍历到不一样的元素,之前的那个元素就是两个节点的公共祖先

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值