题解 | #二叉搜索树的最近公共祖先#
二叉搜索树的最近公共祖先
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`
}
}
