求解最近公共祖先的算法
分为两个步骤:
- 求出两节点路径
- 取两路径上最后一个相同的节点(该节点即为p,q节点的最近公共祖先)
节点路径的算法设计与实现
求节点路径即输入二叉树根节点与待求节点返回根节点到该节点路径上的所有节点。
具体有如下几个要点:
- 我们需要设置一个栈,存储最终的节点路径。找到该节点时,从栈底到栈顶存储的节点即为从根节点到该节点的路径。
- 需要通过遍历算法,从根节点遍历至该节点。树的遍历算法可以是递归的深度优先搜索算法。找到该节点后就结束搜索。
- 将遍历过程中遇到的节点按照顺序存储到栈中。节点遍历完成之后需要弹出栈,从而保证栈中存储的节点时根节点到当前遍历节点路径上的节点。
具体代码
深度优先搜索寻找路径上的节点
利用两节点的路径寻找最近公共祖先