【leetcode hot 100 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 helper(nums, 0, nums.length-1);
    }

    public TreeNode helper(int[] nums, int left, int right){
        if(left>right){
            return null;
        }
        // 取中间或中间左边的元素为根节点
        int mid = (left+right)/2;
        TreeNode node = new TreeNode(nums[mid]);
        node.left = helper(nums, left, mid-1);
        node.right = helper(nums, mid+1, right);
        return node;
    }
}
相关推荐
KhalilRuan13 分钟前
代码随想录-训练营-day52
算法
moz与京25 分钟前
【附JS、Python、C++题解】Leetcode面试150题(9)——三数之和
javascript·c++·leetcode
nqqcat~35 分钟前
函数的引用/函数的默认参数/函数的占位参数/函数重载
开发语言·c++·算法
云一One1 小时前
RAG文本分块策略——语义分块
算法
香菇滑稽之谈1 小时前
抽象工厂模式的C++实现示例
c++·算法·设计模式·抽象工厂模式
稀土村长1 小时前
二叉堆的介绍以及代码解析上浮和下浮原理
java·数据结构
yadanuof2 小时前
leetcode hot100普通动态规划/基础DP
算法·leetcode·动态规划
酷酷的崽7982 小时前
如何在AVL树中高效插入并保持平衡:一步步掌握旋转与平衡因子 —— 旋转篇
c语言·数据结构·c++·算法
宇寒风暖2 小时前
一文弄懂编辑距离算法(Levenshtein Distance)示例,通过动态规划计算两个字符串之间的最小编辑操作次数(插入、删除、替换)
开发语言·数据结构·笔记·学习·算法·动态规划
一只码代码的章鱼2 小时前
数据结构与算法-图论-二分图
算法·图论