寻找二叉树中两个节点的最近的公共祖先
来源:互联网 发布:大数据分析报告撰写 编辑:程序博客网 时间:2024/05/16 08:46
题目:要求寻找二叉树中两个节点的最近的公共祖先,并将其返回。
class Node { Node * left; Node * right; Node * parent; }; /*查找p,q的最近公共祖先并将其返回。*/ Node * NearestCommonAncestor(Node * p,Node * q);算法思想:这道题的关键在于每个节点中包含指向父节点的指针,这使得程序可以用一个简单的算法实现。首先给出p的父节点p->parent,然后将q的所有父节点依次和p->parent作比较,如果发现两个节点相等,则该节点就是最近公共祖先,直接将其返回。如果没找到相等节点,则将q的所有父节点依次和p->parent->parent作比较......直到p->parent==root。
Node * NearestCommonAncestor(Node * root,Node * p,Node * q) { Node * temp; while(p!=NULL) { p=p->parent; temp=q; while(temp!=NULL) { if(p==temp->parent) return p; temp=temp->parent; } } }
- 二叉树问题——寻找二叉树中两个节点的最近公共祖先
- 二叉树中两个节点的最近公共祖先节点
- 二叉树中两个节点的最近公共祖先节点
- 二叉树中两个节点的最近公共祖先节点
- 二叉树中两个节点的最近公共祖先节点
- 寻找二叉树中两个节点的最近的公共祖先——迅雷笔试归来
- 寻找二叉树中两个节点的最近的公共祖先
- 寻找二叉树中两个节点的最近的公共祖先
- 寻找二叉树中两个节点的最近祖先
- 求二叉树中两个节点的最近公共祖先
- 求二叉树中两个节点的最近公共祖先
- 求二叉树中两个节点的最近公共祖先
- 求二叉树中两个节点的最近公共祖先
- 求二叉树中两个节点的最近公共祖先
- 二叉树中找到两个节点的最近公共祖先
- 寻找两个节点的最近公共祖先
- 寻找二叉树两节点的最近的公共祖先
- 寻找二叉树两个节点的最低公共祖先(LCA)
- 令人费解的bind函数
- debian移动硬盘不能识别其中几个盘
- svn客户端和服务端安装
- ASIHTTPRequest-使用download cache
- [置顶] 我的六年程序之路
- 寻找二叉树中两个节点的最近的公共祖先
- 显示baseline的SQL的执行计划内容
- ASIHTTPRequest-流量控制
- SVN常用命令
- 自定义UItableView的实现以及组件不可见的问题及解决
- Hibernate查询详解
- ASIHTTPRequest-客户端证书支持
- RT5350调试总结
- ASIHTTPRequest-使用代理连接