邢台网站建设行情,杭州洛可可设计公司,微网站开发 php,wordpress 图片 主题学习目标#xff1a; 669. 修剪二叉搜索树 108.将有序数组转换为二叉搜索树 538.把二叉搜索树转换为累加树 学习内容#xff1a;
669. 修剪二叉搜索树
题目链接文章讲解 给你二叉搜索树的根节点 root #xff0c;同时给定最小边界low 和最大边界 high。通过修剪…学习目标 669. 修剪二叉搜索树 108.将有序数组转换为二叉搜索树 538.把二叉搜索树转换为累加树 学习内容
669. 修剪二叉搜索树
题目链接文章讲解 给你二叉搜索树的根节点 root 同时给定最小边界low 和最大边界 high。通过修剪二叉搜索树使得所有节点的值在[low, high]中。修剪树 不应该 改变保留在树中的元素的相对结构 (即如果没有被移除原有的父代子代关系都应当保留)。 可以证明存在 唯一的答案 。
所以结果应当返回修剪好的二叉搜索树的新的根节点。注意根节点可能会根据给定的边界发生改变。
class Solution {public TreeNode trimBST(TreeNode root, int low, int high) {if(root null) return null;//节点不在删除范围内要继续判断其子树if(root.val low) return trimBST(root.right, low, high);if(root.val high) return trimBST(root.left, low, high);root.left trimBST(root.left, low, high);root.right trimBST(root.right, low, high);return root;}
}108.将有序数组转换为二叉搜索树
题目链接文章讲解
class Solution {public TreeNode sortedArrayToBST(int[] nums) {if(nums.length 0) return null;return traversal(nums, 0, nums.length - 1);}//左闭右闭区间public TreeNode traversal(int[] nums, int left, int right){if(left right) return null;int mid ( left right ) / 2;TreeNode root new TreeNode(nums[mid]);root.left traversal(nums, left, mid - 1);root.right traversal(nums, mid 1, right);return root;}
}538.把二叉搜索树转换为累加树
题目链接文章讲解 给出二叉 搜索 树的根节点该树的节点值各不相同请你将其转换为累加树Greater Sum Tree使每个节点 node 的新值等于原树中大于或等于 node.val 的值之和。
提醒一下二叉搜索树满足下列约束条件
节点的左子树仅包含键 小于 节点键的节点。 节点的右子树仅包含键 大于 节点键的节点。 左右子树也必须是二叉搜索树
class Solution {//前一个节点的数值private int pre 0;public TreeNode convertBST(TreeNode root) {if(root null) return null;traversal(root);return root;}public void traversal(TreeNode node){if(node null) return;traversal(node.right);node.val node.val pre;pre node.val;traversal(node.left);return;}
}