当前位置: 首页 > news >正文

[leetcode hot 150]第一百零八题,将有序数组转换为二叉搜索树

题目:给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 

平衡二叉搜索树。

 给定一个有序的整数数组,我们需要构建一棵平衡的二叉搜索树。平衡二叉树是指任意一个节点的左右子树的高度差不超过1。

由于给定的数组是有序的,可以利用这个特性来构建二叉搜索树。可以选择数组中间的元素作为根节点,然后递归地构建左子树和右子树。

 

public class no_108 {public static void main(String[] args) {int[] arr = {-10, -3, 0, 5, 9};TreeNode treeNode = sortedArrayToBST(arr);}public static TreeNode sortedArrayToBST(int[] nums) {return buildTree(nums, 0, nums.length - 1);}public static TreeNode buildTree(int[] nums, int left, int right) {if (left > right) return null;int mid = left + (right - left) / 2;TreeNode root = new TreeNode(nums[mid]);root.left = buildTree(nums, left, mid - 1);root.right = buildTree(nums, mid + 1, right);return root;}
}

利用有序数组的特点,将树构建出来。

http://www.lryc.cn/news/363983.html

相关文章:

  • 科普丨什么是数字孪生灌区(平台)?如何建设?有何好处?
  • Python爬虫如何入门:一步步走向精通的指南
  • Linux用户和用户组的操作
  • git命令行分支(增删改查)
  • 地理加权回归GWR简介
  • 康谋技术 | 自动驾驶:揭秘高精度时间同步技术(一)
  • 客户端被攻击怎么办,为什么应用加速这么适合
  • Introduction to HAL3
  • Vue02-搭建Vue的开发环境
  • Python | 句子缩写
  • STM32自己从零开始实操04:显示电路原理图
  • 数分—AB测试
  • 基于全志T507-H的Igh EtherCAT主站案例分享
  • 刷题记录(20240605)
  • CUDA和OpenGL纹理texture结合
  • 市场凌乱,智能算法哪种效果好?
  • 学会这14大招,30天涨粉两三千没问题!沈阳新媒体运营培训
  • SQL数据库性能优化
  • eNSP学习——RIP路由协议基础配置
  • 备考系统架构设计师,看这篇就够了!(包括核心总结、真题、论文、模拟试题索引)
  • stm32编译原理
  • 如何以JNI方式实现安卓APP控制GPIO?
  • 计算机网络学习笔记——运输层(b站)
  • HBase数据库面试知识点:第二部分 - 核心技术(持续更新中)
  • Spring 使用SSE(Server-Sent Events)学习
  • 词法分析器的设计与实现--编译原理操作步骤,1、你的算法工作流程图; 2、你的函数流程图;3,具体代码
  • linux查看磁盘类型命令
  • 多线程调用同一个不包含可变状态,并且是线程安全的方法时,可同时执行,不必等待排队
  • Java文件操作①——XML文件的读取
  • 【记录】网络|没有路由器没有网线,分别使用手机或Windows电脑共享网络给ARM64开发板,应急连接