998. Maximum Binary Tree II

大致题意:输入为一棵树的根节点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呢 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值