关闭

LeetCode Convert Sorted Array to Binary Search Tree

标签: javaleetcodeDFS
99人阅读 评论(0) 收藏 举报
分类:

Description:

Given an array where elements are sorted in ascending order, convert it to a height balanced BST.

Solution:

每次dfs层次中,为了实现平衡,都是二分,取出中间的数值作为根节点的数值。

import java.util.*;

public class Solution {
	int nums[];

	public TreeNode sortedArrayToBST(int[] nums) {
		this.nums = nums;
		return dfs(0, nums.length - 1);
	}

	TreeNode dfs(int start, int end) {
		if(start>end)return null;
		int rootIndex = (start + end) / 2;

		TreeNode root = new TreeNode(nums[rootIndex]);
		root.left = dfs(start, rootIndex - 1);
		root.right = dfs(rootIndex + 1, end);
		return root;
	}
}



0
0

猜你在找
【直播】机器学习&数据挖掘7周实训--韦玮
【套餐】系统集成项目管理工程师顺利通关--徐朋
【直播】3小时掌握Docker最佳实战-徐西宁
【套餐】机器学习系列套餐(算法+实战)--唐宇迪
【直播】计算机视觉原理及实战--屈教授
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之矩阵--黄博士
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之凸优化--马博士
【套餐】Javascript 设计模式实战--曾亮
查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:61358次
    • 积分:3253
    • 等级:
    • 排名:第10408名
    • 原创:288篇
    • 转载:0篇
    • 译文:0篇
    • 评论:4条
    最新评论