二叉树的下一个节点
来源:互联网 发布:python黑帽子中文 编辑:程序博客网 时间:2024/05/17 16:54
给定二叉树和其中一个节点,如何找出中序遍历序列的下一个节点?树中的节点有两个指向左、右子节点的指针,还有一个指向父节点的指针。
分为三种情况:
1. 如果一个节点有右子树,那么它的下一个节点就是它的右节点的最左子节点。
2. 如果一个节点没有右子树,并且该节点是它父节点的左子节点,那么它的下一节点就是它的父节点。
3. 如果一个节点没有右子树,并且还是它父节点的右子节点,那么从该节点开始一直沿着父节点的指针向上遍历,直到找到一个节点是它父节点的左子节点,那么该节点的下一节点就是这个节点的父节点。
2与3都是在该节点没有右子树的情况下,都是要找出该节点是父节点的左子节点的父节点。如果该节点恰好是父节点的左子节点,那么父节点即为下一个节点。
如果该节点不是父节点的左子节点,那么一直向上遍历,直到找到一个节点为父节点的左子节点,那么该父节点即为下一节点。
2与3的情况下一节点都是根节点。
public TreeLinkNode GetNext(TreeLinkNode pNode) { if(pNode==null) return null; if(pNode.right!=null){ pNode=pNode.right; while(pNode.left!=null){ pNode=pNode.left; } return pNode; } while(pNode.next!=null&&pNode.next.right==pNode) { pNode=pNode.next; } return pNode.next; }
阅读全文
0 0
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 二叉树的下一个节点
- 找二叉树节点的下一个节点
- 【二叉树】二叉树的下一个节点
- 剑指Offer--二叉树的下一个节点
- 二叉树的下一个节点(中序)
- 求二叉树的下一个节点
- Python:二叉树的下一个节点
- js进行图片相关操作
- linux 软件开发小工具
- 1、面向对象思想 2、类与对象的关系 3、局部变量和成员变量的关系 4、封装思想 5、private,this关键字 6、随机点名器
- day09笔记
- ServletRequest中getReader()和getInputStream()只能调用一次的解决办法
- 二叉树的下一个节点
- LintCode 关于动态规划问题的总结
- 从K近邻算法、距离度量谈到KD树、SIFT+BBF算法
- day10笔记
- HDU 1043 八数码问题 A*搜索+康拓展开+逆序对判断+路径输出
- 隐含马尔科夫模型(HMM)原理及其实现
- spring总结
- 计算1+2+.....+n
- android 网络连接的判断