本文已参与「新人创作礼」活动,一起开启掘金创作之路。
998. 最大二叉树 II
示例 1:
输入:root = [4,1,3,null,null,2], val = 5
输出:[5,4,null,1,3,null,null,2]
解释:a = [1,4,2,3], b = [1,4,2,3,5]
示例 2:
输入:root = [5,2,4,null,1], val = 3
输出:[5,2,4,null,1,null,3]
解释:a = [2,1,5,4], b = [2,1,5,4,3]
示例 3:
输入:root = [5,2,3,null,1], val = 4
输出:[5,2,4,null,1,3]
解释:a = [2,1,5,3], b = [2,1,5,3,4]
数据范围:
树中节点数目在范围 [1, 100] 内
1 <= Node.val <= 100
树中的所有值 互不相同
1 <= val <= 100
思路
首先要搞清楚是如何构建这颗树的 比如
[3,2,1,6,0,5]的构造
最后形成这样一颗树
若是我们要插入一个新节点,有哪几种情况呢?
若是大于当前点,当前点是不是一定是他的左儿子
(因为新的点一定插入在最后面)
若是大于所有点,是不是相当于所有点都是这个点的左子树
所以,递归的去分割即可
代码
class Solution {
TreeNode* rebuild(TreeNode* root, TreeNode* now) {
if (root->val < now->val) {
now->left = root;
root = now;
} else {
if (root->right == nullptr) root->right = now;
else {
if (root->right->val < now->val) {
now->left = root->right;
root->right = now;
} else {
root->right = rebuild(root->right, now);
}
}
}
return root;
}
public:
TreeNode* insertIntoMaxTree(TreeNode* root, int val) {
root = rebuild(root, new TreeNode(val));
return root;
}
};