博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法-树-将有序数组转化为二叉搜索树
阅读量:3963 次
发布时间:2019-05-24

本文共 847 字,大约阅读时间需要 2 分钟。

在这里插入图片描述

/** * 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 help(nums, 0, nums.length - 1); } public TreeNode help(int[] arr, int left, int right) {
//采用二分法 取中间的一个元素作为根节点 这样可以保证高度差不超过一 if(left > right) {
return null; } int mid = left + (right - left) / 2; TreeNode root = new TreeNode(arr[mid]); root.left = help(arr, left, mid - 1); root.right = help(arr, mid + 1, right); return root; }}

转载地址:http://zmhzi.baihongyu.com/

你可能感兴趣的文章
人生必修的181条佛理
查看>>
The Most Widely Used Java Libraries
查看>>
简单在单机使用apache-james(开源邮件服务器)
查看>>
lsof 快速起步
查看>>
跨平台Java程序注意事项
查看>>
Python字符与数字的相互转换
查看>>
C 指针解读
查看>>
有关乱码的处理---中国程序员永远无法避免的话题
查看>>
JSP的运行内幕
查看>>
python超简单的web服务器
查看>>
代理模式、静态代理、动态代理、aop
查看>>
Struts1.x Spring2.x Hibernate3.x DWR2.x整合工具文档v1.00
查看>>
大型Web2.0站点构建技术初探
查看>>
机器学习算法汇总:人工神经网络、深度学习及其它
查看>>
解决Spring中AOP不能切入Struts的DispatchAction方法的问题
查看>>
出国以后才知道英语应该怎么学
查看>>
计算机专业权威期刊投稿经验总结
查看>>
如何在三个月内学会一门外语?
查看>>
看看你对Linux到底了解多少?
查看>>
网上看到的:ARM入门最好的文章(转)
查看>>