给你二叉搜索树的根节点 root ,同时给定最小边界low 和最大边界 high。通过修剪二叉搜索树,使得所有节点的值在[low, high]中。修剪树 不应该 改变保留在树中的元素的相对结构 (即,如果没有被移除,原有的父代子代关系都应当保留)。 可以证明,存在 唯一的答案 。
所以结果应当返回修剪好的二叉搜索树的新的根节点。注意,根节点可能会根据给定的边界发生改变。
输入:root = [1,0,2], low = 1, high = 2
输出:[1,null,2]
输入:root = [3,0,4,null,2,null,null,1], low = 1, high = 3
输出:[3,2,null,1]
【代码】:
递归即可,不用想复杂了。
/**
* Definition for a binary tree node.
* function TreeNode(val, left, right) {
* this.val = (val===undefined ? 0 : val)
* this.left = (left===undefined ? null : left)
* this.right = (right===undefined ? null : right)
* }
*/
/**
* @param {TreeNode} root
* @param {number} low
* @param {number} high
* @return {TreeNode}
*/
var trim = function(node, low, high){
if(node == null) return null;
if(node){
if(node.val >= low && node.val <= high){
node.left = trim(node.left, low, high);
node.right = trim(node.right, low, high);
return node;
}else if(node.val < low){
return trim(node.right, low, high);
}else if(node.val > high){
return trim(node.left, low, high);
}
}
}
var trimBST = function(root, low, high) {
return trim(root, low, high)
};