5 / 2 6 / 1 4 7 / 3 class Node{ Node left; Node right; Node parent; int val; } /** 1.如果有右子树,则结果为右子树的最左节点。 2.如果没有右子树,则需要回到父节点,如果当前节点是父节点的左子树,则父节点就是结果,如果不是继续向上再找父节点。 */ public TreeNode inorderSucc(TreeNode n){ if(n==null) return null; if(n.right!=null) return leftMost(n.right); TreeNode child = n; TreeNode par =child.parent; while(par!=null&&par.right==child){ child=par; par=par.parent; } return par; } private TreeNode leftMost(TreeNode n){ if(n==null) return null; while(n.left!=null) n=n.left; return n; }