【算法二十六】108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树

108. 将有序数组转换为二叉搜索树

递归:

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public TreeNode sortedArrayToBST(int[] nums) {
        return sort(nums,0,nums.length-1);
    }
    
    private TreeNode sort(int[] nums,int left,int right){
        if(left > right){
            return null;
        }
        int mid = left +(right - left)/2;
        TreeNode root = new TreeNode(nums[mid]);
        TreeNode l = sort(nums,left,mid-1);
        TreeNode r = sort(nums,mid+1,right);
        root.left = l;
        root.right = r;
        return root;
    }
}

时间复杂度:O(N)

空间复杂度:O(N)

98. 验证二叉搜索树

递归:

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean isValidBST(TreeNode root) {
        return isValidBSTCheck(root,Long.MIN_VALUE,Long.MAX_VALUE);
    }
     
     private boolean isValidBSTCheck(TreeNode root,long left,long right){
         if(root == null){
             return true;
         }
         
         long x = root.val;
         //二叉树里不允许有重复值
         if(left >= x || x >= right){
             return false;
         }
         
         if(!isValidBSTCheck(root.left,left,x) || !isValidBSTCheck(root.right,x,right)){
             return false;
         }
         return true;
     }
}

时间复杂度:O(N)

空间复杂度:O(N)

递归总结:昨天总结的不是很全面,递归看三点,终止条件,每一层做什么,给上一层返回什么

相关推荐
Asize17 分钟前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考14 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营16 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队17 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK1 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
_清歌2 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局2 天前
SVD 的三步走:双对角化、Givens 收敛、排序
算法