欢迎来到小猪的博客,希望这期博客能对你有帮助!
前言
如果哪里解析错误或者你不太理解的都可以来私聊我哈~谢谢!
一,题目
将一棵无穷大满二叉树的结点按根结点一层一层地从左往右编号,根结点编号为1。现给定a,b为两个结点。设计一个算法,返回a、b最近的公共祖先的编号。注意其祖先也可能是结点本身。
二,解析
题目所描述的满二叉树如下: 1 / \ 2 3 / \ / \ 4 5 6 7 上述树中子节点与父节点之间的关系为root = child / 2。所以如果a != b,就让其中的较大数除以2, 如此循环直到a == b 即是原来两个数的最近公共祖先 比如: 2和7的最近公共祖先:7/2 = 3 —> 3/2 = 1, 2/2 = 1, 得到1为它们的公共祖先
三,代码
public class Main3 {
public int getLCA(int a,int b){
while (a!=b){
if (a>b){
a/=2;
}else {
b/=2;
}
}
return a;
}
}
这期博客很简单,希望对你有帮助!
记得关注小猪哦!
下期再见啦~