色欲av一区久久精品_久久综合色综合色88_无码在线观看不卡_色黄视频网站_亚洲国产精品久久久久秋霞66

LeetCode 235. 二叉搜索樹的最近公共祖先

時(shí)間:2023-05-16

package leetcode;

/**
* @author ZhouJie
* @date 2020年5月13日 下午12:49:27
* @Description: 235. 二叉搜索樹的最近公共祖先
*
*/
public class LeetCode_0235 {

}

//Definition for a binary tree node.
class TreeNode_0235 {
int val;
TreeNode_0235 left;
TreeNode_0235 right;

TreeNode_0235(int x) {
val = x;
}
}

class Solution_0235 {
/**
* @author: ZhouJie
* @date: 2020年5月13日 下午12:51:13
* @param: @param root
* @param: @param p
* @param: @param q
* @param: @return
* @return: TreeNode_0235
* @Description: 1-二叉搜索樹的特性,父節(jié)點(diǎn)大于左節(jié)點(diǎn)小于右節(jié)點(diǎn)
*
*/
public TreeNode_0235 lowestCommonAncestor_1(TreeNode_0235 root, TreeNode_0235 p, TreeNode_0235 q) {
if (root == null) {
return root;
// pq值均大于root值,則祖節(jié)點(diǎn)在左子樹中
} else if (root.val > p.val && root.val > q.val) {
return lowestCommonAncestor_1(root.left, p, q);
// pq值均小于root值,則祖節(jié)點(diǎn)在右子樹中
} else if (root.val < p.val && root.val < q.val) {
return lowestCommonAncestor_1(root.right, p, q);
// pq值其一等于root值
} else {
return root;
}
}

/**
* @author: ZhouJie
* @date: 2020年5月13日 下午12:51:26
* @param: @param root
* @param: @param p
* @param: @param q
* @param: @return
* @return: TreeNode_0235
* @Description: 2-直接遞歸校驗(yàn)節(jié)點(diǎn);
*
*/
public TreeNode_0235 lowestCommonAncestor_2(TreeNode_0235 root, TreeNode_0235 p, TreeNode_0235 q) {
if (root == null || root == p || root == q) {
return root;
} else {
TreeNode_0235 left = lowestCommonAncestor_2(root.left, p, q);
TreeNode_0235 right = lowestCommonAncestor_2(root.right, p, q);
// 可以一行返回,但是可讀性不好
// return left == null ? right : (right == null ? left : root);
if (left == null) {
return right;
} else if (right == null) {
return left;
} else {
return root;
}
}
}
}

文章標(biāo)簽:

Copyright ? 2016 廣州思洋文化傳播有限公司,保留所有權(quán)利。 粵ICP備09033321號(hào)

與項(xiàng)目經(jīng)理交流
掃描二維碼
與項(xiàng)目經(jīng)理交流
掃描二維碼
與項(xiàng)目經(jīng)理交流
ciya68