题目简介:
最大树 定义:一棵树,并满足:其中每个节点的值都大于其子树中的任何其他值。
给你最大树的根节点 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 | /** |