二叉树的下一个节点(中序)
2016-06-30 17:27
267 查看
题目描述
给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。/*
public class TreeLinkNode {
int val;
TreeLinkNode left = null;
TreeLinkNode right = null;
TreeLinkNode next = null;//父节点
TreeLinkNode(int val) {
this.val = val;
}
}
*/
/*
*1、有右子树的,那么下个结点就是右子树最左边的点;
*2、没有右子树的,也可以分成两类,a)是父节点左孩子,那么父节点就是下一个节点 ;
*b)是父节点的右孩子找他的父节点的父节点的父节点...
*直到当前结点是其父节点的左孩子位置。如果没有,那么他就是尾节点。
*/
public class Solution {
public TreeLinkNode GetNext(TreeLinkNode pNode)
{
if(pNode == null) {
return null;
}
if(pNode.right != null) {
pNode = pNode.right;
while(pNode != null && pNode.left != null) {
pNode = pNode.left;
}
return pNode;
}
while(pNode.next != null) {
if(pNode.next.left == pNode) {
return pNode.next;
}
pNode = pNode.next;
}
return null;
}
}
相关文章推荐
- 解决Andriod全屏时软键盘出现不能把原来的布局给顶上去的方法
- JAX-RS入门 二 :运行
- 深入浅出 - Android系统移植与平台开发(五)- 编译Android源码
- Hive知识点笔记-影印版
- 爬虫技术(2)--抓取网页java代码实现
- Unity3D异步加载游戏场景
- 【那些年遇到过的面试题】traceroute和tracert有什么区别
- CentOS7配置samba共享服务
- [精通Objective-C]对象和消息传递
- solr 6.1 服务端 tomcat 搭建及调用
- Xcode描述文件的位置
- 判断相册中是否存在某张照片
- Vagrant命令(二)
- flex布局模式简单概述
- AAPT: libpng error: Not a PNG file 问题解决
- 这个browse()方法可能抛出各种类型的异常
- LeetCode - 73. Set Matrix Zeros
- 这个browse()方法可能抛出各种类型的异常
- 简单线程池的实现
- GET和POST有什么区别?及为什么网上的多数答案都是错的。