题解 | #二叉搜索树的最近公共祖先#

二叉搜索树的最近公共祖先

https://www.nowcoder.com/practice/d9820119321945f588ed6a26f0a6991f

kotlin
/**
 * class TreeNode(var `val`: Int) {
 *     var left: TreeNode? = null
 *     var right: TreeNode? = null
 * }
 */
object Solution {
    /**
    * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
    *
    * 
        * @param root TreeNode类 
        * @param p int整型 
        * @param q int整型 
        * @return int整型
    */
    fun lowestCommonAncestor(root: TreeNode?,p: Int,q: Int): Int  {
        return dfs(root!!, p, q)
    }
    
    private fun dfs(root: TreeNode, p: Int, q: Int): Int {
        //利用搜索树左子树的值都小于当前值,右子树都大于当前值来判断。当前节点不满足同时大于p和q,并且不满足同时小于右子树,即遇到了需要左右分开或当前节点等于p,q中的一个即为父节点
        if(root.left != null && root.`val` > p && root.`val` > q) return  dfs(root.left!!, p, q)
        else if(root.right != null && root.`val` < p && root.`val` < q) return dfs(root.right!!, p, q)
        return root.`val`
    }
}


全部评论

相关推荐

头像
05-27 20:32
已编辑
深度学习
工行数据中心 偏运维养老 到手可能18w
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务