力扣 | 236. 二叉树的最近公共祖先
2023-12-14 18:29:09
用HashMap维护好子节点和父节点的关系
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
public class TreeNode {
int val;
TreeNode left;
TreeNode right;
public TreeNode() {
}
public TreeNode(int val) {
this.val = val;
}
public TreeNode(int val, TreeNode left, TreeNode right) {
this.val = val;
this.left = left;
this.right = right;
}
}
public class Problem_236_LowestCommonAnstor {
public TreeNode lowestCommonAnster(TreeNode root,TreeNode p,TreeNode q){
Map<Integer,TreeNode> parent = new HashMap<>();
dfs(root,parent);
Set<Integer> visited = new HashSet<>();
while (p != null){
visited.add(p.val);
p = parent.get(p.val);
}
while (q != null){
if(visited.contains(q.val))return q;
q = parent.get(q.val);
}
//如果有一个为null的话 其公共祖先为 null
return null;
}
public void dfs(TreeNode root,Map<Integer,TreeNode> parent){
if(root == null)return;
if(root.left != null)parent.put(root.left.val, root);
if(root.right != null)parent.put(root.right.val,root);
dfs(root.left,parent);
dfs(root.right,parent);
}
}
文章来源:https://blog.csdn.net/qq_37247026/article/details/134997693
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!