zoukankan      html  css  js  c++  java
  • Java实现 LeetCode 108 将有序数组转换为二叉搜索树

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

    将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树。

    本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1。

    示例:

    给定有序数组: [-10,-3,0,5,9],

    一个可能的答案是:[0,-3,9,-10,null,5],它可以表示下面这个高度平衡二叉搜索树:

          0
         / 
       -3   9
       /   /
     -10  5
    
     
    class Solution {
         public TreeNode sortedArrayToBST(int[] nums) {
            // 左右等分建立左右子树,中间节点作为子树根节点,递归该过程
            return nums == null ? null : buildTree(nums, 0, nums.length - 1);
        }
    
        private TreeNode buildTree(int[] nums, int l, int r) {
            if (l > r) {
                return null;
            }
            int m = l + (r - l) / 2;
            TreeNode root = new TreeNode(nums[m]);
            root.left = buildTree(nums, l, m - 1);
            root.right = buildTree(nums, m + 1, r);
            return root;
        }
    }
    
  • 相关阅读:
    基本背包问题
    linux 共享内存实现
    Linux内存管理原理
    从inet_pton()看大小端字节序
    linux线程的实现
    简述memcached中的一致哈希
    c语言实现面向对象OOC
    论记忆力
    关于编程内存泄漏
    一道常考fork题挖掘
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13075546.html
Copyright © 2011-2022 走看看