题目简介:
最大树 定义:一棵树,并满足:其中每个节点的值都大于其子树中的任何其他值。
给你最大树的根节点 root 和一个整数 val 。
就像 之前的问题 那样,给定的树是利用 Construct(a) 例程从列表 a(root = Construct(a))递归地构建的:
- 如果
a为空,返回null。 - 否则,令
a[i]作为a的最大元素。创建一个值为a[i]的根节点root。 root的左子树将被构建为Construct([a[0], a[1], ..., a[i - 1]])。root的右子树将被构建为Construct([a[i + 1], a[i + 2], ..., a[a.length - 1]])。- 返回
root。
请注意,题目没有直接给出 a ,只是给出一个根节点 root = Construct(a) 。
假设 b 是 a 的副本,并在末尾附加值 val。题目数据保证 b 中的值互不相同。
返回 Construct(b) 。
示例 1:


1 | 输入:root = [4,1,3,null,null,2], val = 5 |
提示:
- 树中节点数目在范围
[1, 100]内 1 <= Node.val <= 100- 树中的所有值 互不相同
1 <= val <= 100
思路:
当val是数组中最大的值时,直接将其作为根节点,并将原来的根节点作为其左子树即可(val添加在末端)。
否则,由于val在末端,所以我们需要遍历根节点的右节点:
- 若
val大于某个右节点的值,则将val作为该右节点父节点的新右节点,并将原右节点作为其左节点。 - 若没有大于任何一个右节点,则将其作为最后一个右节点的右节点即可。
代码如下:
1 | /** |