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

IT技术2年前 (2022)发布 投稿用户
0

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-二叉搜索树的特性,父节点大于左节点小于右节点
*
*/
public TreeNode_0235 lowestCommonAncestor_1(TreeNode_0235 root, TreeNode_0235 p, TreeNode_0235 q) {
if (root == null) {
return root;
// pq值均大于root值,则祖节点在左子树中
} else if (root.val > p.val && root.val > q.val) {
return lowestCommonAncestor_1(root.left, p, q);
// pq值均小于root值,则祖节点在右子树中
} 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-直接递归校验节点;
*
*/
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;
}
}
}
}

© 版权声明
好牛新坐标 广告
版权声明:
1、IT大王遵守相关法律法规,由于本站资源全部来源于网络程序/投稿,故资源量太大无法一一准确核实资源侵权的真实性;
2、出于传递信息之目的,故IT大王可能会误刊发损害或影响您的合法权益,请您积极与我们联系处理(所有内容不代表本站观点与立场);
3、因时间、精力有限,我们无法一一核实每一条消息的真实性,但我们会在发布之前尽最大努力来核实这些信息;
4、无论出于何种目的要求本站删除内容,您均需要提供根据国家版权局发布的示范格式
《要求删除或断开链接侵权网络内容的通知》:https://itdw.cn/ziliao/sfgs.pdf,
国家知识产权局《要求删除或断开链接侵权网络内容的通知》填写说明: http://www.ncac.gov.cn/chinacopyright/contents/12227/342400.shtml
未按照国家知识产权局格式通知一律不予处理;请按照此通知格式填写发至本站的邮箱 wl6@163.com

相关文章