前言
仅记录学习笔记,如有错误欢迎指正。
题目
给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。.1.对于该题的最近的公共祖先定义:对于有根树T的两个结点p、q,最近公共祖先LCA(T,p,q)表示一个结点x,满足x是p和q的祖先且x的深度尽可能大。在这里,一个节点也可以是它自己的祖先.
2.二叉搜索树是若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值.
3.所有节点的值都是唯一的。.
4.p、q 为不同节点且均存在于给定的二叉搜索树中。.
.
如果给定以下搜索二叉树: {7,1,12,0,4,11,14,#,#,3,5},如下图:
示例:
-
输入:{7,1,12,0,4,11,14,#,#,3,5},1,12
-
输出: 7
解法
根据二叉搜索树树的性质来定位父节点的位置,递归找。import java.util.*;
/*
* public class TreeNode {
* int val = 0;
* TreeNode left = null;
* TreeNode right = null;
* public TreeNode(int val) {
* this.val = val;
* }
* }
*/
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param root TreeNode类
* @param p int整型
* @param q int整型
* @return int整型
*/
public int lowestCommonAncestor (TreeNode root, int p, int q) {
// 都比父节点大,右子树找
if(root.val < p && root.val<q){
return lowestCommonAncestor(root.right,p,q);
}
if (root.val>p&&root.val>q){
return lowestCommonAncestor(root.left,p,q);
}
return root.val;
}
}