题目描述
给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。
- public static class TreeLinkNode {
- int val;
- TreeLinkNode left = null;
- TreeLinkNode right = null;
- TreeLinkNode next = null;
-
- TreeLinkNode(int val) {
- this.val = val;
- }
- }
-
- TreeLinkNode GetNext(TreeLinkNode pNode){
- if(pNode==null) return null;
- if(pNode.next==null){
- if(pNode.right==null) return null;
- pNode = pNode.right;
- while(pNode.left!=null) pNode=pNode.left;
- return pNode;
- }else if(pNode.next.left==pNode){
- if(pNode.right==null) return pNode.next;
- pNode = pNode.right;
- while(pNode.left!=null) pNode=pNode.left;
- return pNode;
- }else if(pNode.next.right==pNode){
- if(pNode.right!=null) return pNode.right;
- while(pNode.next!=null && pNode.next.right==pNode) pNode=pNode.next;
- if(pNode.next==null) return null;
- return pNode.next;
- }
- return null;
- }
原文链接http://blog.youkuaiyun.com/crazy__chen/article/details/45101775