剑指offer-二叉树的下一个结点
来源:互联网 发布:linux lsnrctl 编辑:程序博客网 时间:2024/05/01 07:14
题目描述
给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。
分析
二叉树的下一个节点,一共有以下情况:
1.二叉树为空,则返回空;
2.节点右孩子存在,则设置一个指针从该节点的右孩子出发,一直沿着指向左子结点的指针找到的叶子节点即为下一个节点;
3.节点不是根节点。如果该节点是其父节点的左孩子,则返回父节点;否则继续向上遍历其父节点的父节点,重复之前的判断,返回结果。
class TreeLinkNode { int val; TreeLinkNode left = null; TreeLinkNode right = null; TreeLinkNode next = null; TreeLinkNode(int val) { this.val = val; }}public class Solution { public TreeLinkNode GetNext(TreeLinkNode pNode) { // 1:判断是否为空 if(pNode == null){ return null; } // 2:判断是否有右子树,如果有,找到右子树中序遍历的第一个结点,即为所得节点。 else if(pNode.right!=null){ pNode=pNode.right; while(pNode.left!=null){ pNode=pNode.left; } return pNode; } // 3:判断是否是根节点 // 如果不是:判断是否是父节点的左子树,如果是,返回父节点; // 如果不是,继续向上遍历父节点,判断是否是父节点的左子树,直到根节点,如果找不到,返回null else{ while(pNode.next!=null){ if(pNode==pNode.next.left){ return pNode.next; }else{ pNode=pNode.next; } } return null; } }}
0 0
- 剑指offer--二叉树的下一个结点
- 《剑指offer》二叉树的下一个结点
- 《剑指offer》-- 二叉树的下一个结点
- 剑指offer:二叉树的下一个结点
- 剑指offer:二叉树的下一个结点
- [剑指offer]二叉树的下一个结点
- 剑指offer-二叉树的下一个结点
- 《剑指offer》二叉树的下一个结点
- 剑指offer: 二叉树的下一个结点
- 剑指offer 二叉树的下一个结点
- 剑指offer-二叉树的下一个结点
- 【剑指offer】二叉树的下一个结点
- 剑指offer:二叉树的下一个结点
- 剑指offer--二叉树的下一个结点
- 剑指offer:二叉树的下一个结点
- 剑指offer:二叉树的下一个结点
- 剑指offer:二叉树的下一个结点
- 剑指offer 二叉树的下一个结点
- Android 静默安装和智能安装的实现方法
- 5-24 树种统计 (25分)
- Unity3D之Vector3.Dot和Vector3.Cross的使用
- C++引用的实质
- OC-FUNDATION-NSDictionary&NSMutableDictionary&Block
- 剑指offer-二叉树的下一个结点
- C#答题程序
- 着鲜衣,卸心防,未曾料得竟痴狂。倾所有,尽所知,人世斑斓与之尝。百般思量,千言万语不成章,谨以嘘寒问短道天凉。人生难得几回醉……无妨无妨。
- python 中的私有变量申明和定义
- MySQL数据库中常用存储引擎总结
- 寻觅
- TCP拥塞控制-慢启动、拥塞避免、快重传、快启动
- 【每天听见吴晓波】为什么要听见吴晓波?
- Mac OS X 10.11.x 安装 Cocoapods 心路历程