- 题目描述:
给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。
- 解题思路:
- 给定一个pNode节点,找此节点按中序遍历的下一个节点,先判断pNode有无右子树,如果有再判断pNode的右子树有无左子树,若有左子树则返回此左子树,若无左子树则返回pNode的右子树,毕竟中序遍历的顺序为“左根右”;若pNode无右子树,则找pNode的下一个节点(按中序遍历的顺序),再判断有无右子树
- 代码:
/*
public 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)
{
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){
if(pNode.next.left== pNode){
return pNode.next;
}
pNode = pNode.next;
}
return null;
}
}