大致题意:输入为一棵树的根节点A,再加入一个新值val,要求输出重建之后的树
树的形成过程:先找出序列中的最大值作为根,设其下标为 i ,根的左子树由原序列下标为0, 1, 2, ...... i - 1 构成,根的右子树由原序列下标为i + 1, ...... n - 1构成
最直白的思路:先中根遍历,恢复原始序列,再加上新值 val ,重复树的形成过程建树
但是感觉上述过程没有充分利用已有的树结构,如果 新增值 val 比原序列最大值大, 则将原来的整棵树作为新值的左子树;如果新增值val 比原序列最大值小,则要将val插入到原树的右子树,重复插到右子树这个过程直到val是最大的值,之后应该是递归处理
自己实现代码还是不行,这个递归实现思路没想明白,看的discussion
class Solution {
public TreeNode insertIntoMaxTree(TreeNode root, int val) {
if( root == null )return new TreeNode(val);
if( val > root.val ){
TreeNode res = new TreeNode( val );
res.left = root;
return res;
}
root.right = insertIntoMaxTree( root.right , val );
return root;
}
}
emmm 下次要用python写,毕竟还没怎么熟悉过Python呢