[LeetCode OJ]- Convert Sorted Array to Binary Search Tree

题目要求:给定一个升序排列的一维数组,根据这个数组生成一颗高度平衡的二叉排序树。

例如A=[1,2,3,4,5,6,7,8];

生成的二叉排序树


思想:使用二分法来求解。

数组的low,high,middle分别指向当前范围内数组的最低位、最高位和中间位置。middle位置处付给当前树的树根,[low,middle-1]的节点都是当前树的左子树节点,[middle+1,high]的节点都是当前树的右子树节点,……如此循环直到low不再大于high为止。

也就是

当low<high时,左右子树继续二分;

当low == high时,此时的节点为叶子节点,返回叶子节点;

当low>high时,此时无节点,返回空。

另外,还有特殊情况也需要考虑,当给的数组为空时的处理。

代码如下。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 5,143评论 0 12
  • 原文出处:http://www.cnblogs.com/maybe2030/p/4715035.html引文出处:...
    明教de教主阅读 9,217评论 0 7
  • 树的概述 树是一种非常常用的数据结构,树与前面介绍的线性表,栈,队列等线性结构不同,树是一种非线性结构 1.树的定...
    Jack921阅读 4,475评论 1 31
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,767评论 0 33
  • 我把最甜美的果实 留在最后 我把最惦念的味道 留在最后 我把最心爱的衣服 留在最后 我把最精彩的章节 留在最后 我...
    握瑜阅读 346评论 0 11