不同的二叉搜索树II
时间:2022-07-22
本文章向大家介绍不同的二叉搜索树II,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
问题描述:
给定一个整数 n,生成所有由 1 … n 为节点所组成的 二叉搜索树 。
示例:
输入:3
输出:
[
[1,null,3,2],
[3,2,null,1],
[3,1,null,null,2],
[2,1,3],
[1,null,2,null,3]
]
解释:
以上的输出对应以下 5 种不同结构的二叉搜索树:
1 3 3 2 1
/ / /
3 2 1 1 3 2
/ /
2 1 2 3
提示:
0 <= n <= 8
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/unique-binary-search-trees-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解决方案
该问题是不同的二叉搜索树的升级版,该问题需要将所有可能的二叉树都重建出来。大体思路还是相同,枚举出头结点,再利用头结点将当前序列一分为2分别作为其左子树和右子树。
定义process(left, right)返回从[left,right]可以构成不同的树的集合,process(1, n)即为所求。
首先从left到right枚举出根结点,将枚举出的根结点记做val,然后分别计算其左子树process(left, val - 1),右子树process(val + 1, right),然后对其左右子树组合。
class Solution {
public List<TreeNode> generateTrees(int n) {
if(n == 0){
return new ArrayList<>(0);
}
return process(1, n);
}
// 创建多棵根结点为val,左子树为[left, val - 1] 右子树为[val + 1, right] 其中 left <= val <= right
public List<TreeNode> process(int left, int right){
if(left > right){
List<TreeNode> ans = new ArrayList<>(1);
ans.add(null);
return ans;
}
List<TreeNode> ans = new ArrayList<>(right - left + 1);
for(int i = left; i <= right; i++){
List<TreeNode> leftNodes = process(left, i - 1);
List<TreeNode> rightNodes = process(i + 1, right);
for(TreeNode lNode : leftNodes){
for(TreeNode rNode : rightNodes){
ans.add(new TreeNode(i, lNode, rNode));
}
}
}
return ans;
}
}
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法