LeetCode题练习与总结:不同的二叉搜索树Ⅱ--95

一、题目描述

给你一个整数 n ,请你生成并返回所有由 n 个节点组成且节点值从 1n 互不相同的不同 二叉搜索树 。可以按 任意顺序 返回答案。

示例 1:

输入:n = 3
输出:[[1,null,2,null,3],[1,null,3,2],[2,1,3],[3,1,null,null,2],[3,2,null,1]]

示例 2:

输入:n = 1
输出:[[1]]

提示:

  • 1 <= n <= 8

二、解题思路

我们可以使用递归的方法来解决这个问题。递归的基本思想是,对于每个数i,作为根节点,其左子树由[1, i-1]构成,其右子树由[i+1, n]构成。对于左子树和右子树,我们又可以应用同样的方法来生成所有可能的BST。

  1. 递归基准情况: 如果n小于1,那么没有节点可以用来构建树,返回空列表。
  2. 递归分解: 对于每个数i,作为可能的根节点,递归地为左子树和右子树生成所有可能的BST。
  3. 合并结果: 对于每个根节点i,我们需要将所有可能的左子树和右子树进行组合,得到所有可能的BST。

三、具体代码

import java.util.List;
import java.util.ArrayList;public class Solution {public List<TreeNode> generateTrees(int n) {if (n == 0) {return new ArrayList<>();}return generateSubtrees(1, n);}private List<TreeNode> generateSubtrees(int start, int end) {List<TreeNode> subtrees = new ArrayList<>();if (start > end) {subtrees.add(null); // 添加空树作为递归基准情况return subtrees;}for (int i = start; i <= end; i++) {// 生成所有可能的左子树List<TreeNode> leftSubtrees = generateSubtrees(start, i - 1);// 生成所有可能的右子树List<TreeNode> rightSubtrees = generateSubtrees(i + 1, end);// 将左子树和右子树与根节点i组合for (TreeNode left : leftSubtrees) {for (TreeNode right : rightSubtrees) {TreeNode root = new TreeNode(i);root.left = left;root.right = right;subtrees.add(root);}}}return subtrees;}
}

四、时间复杂度和空间复杂度

1. 时间复杂度

时间复杂度的分析基于每个节点作为根节点时,生成所有可能的左子树和右子树的组合。

  • 对于每个节点i作为根节点,左子树的可能数为i-1,右子树的可能数为n-i。

  • 对于每个节点i,我们需要进行(i-1)*(n-i)次操作来生成所有可能的左子树和右子树的组合。

  • 因为我们需要对1到n的每个数都作为根节点进行这样的操作,所以总的时间复杂度为:

    这是因为对于每个节点i,我们都在进行近似n^2次操作,而这样的操作要进行n次。

因此,时间复杂度是O(n^3)。

2. 空间复杂度

空间复杂度的分析基于递归调用栈的深度以及存储所有生成的树结构的空间。

(1)递归调用栈的深度:递归调用栈的最大深度是O(n),因为每次递归都会减少一个数字直到没有数字剩余。

(2)存储所有生成的树结构的空间

  • 总共有卡特兰数C(n)个不同的二叉搜索树。
  • 每个树的结构最多有O(n)个节点。
  • 因此,总的空间复杂度是O(n) * C(n)。

卡特兰数C(n)的增长速度是O(4^n / n^1.5),所以总的空间复杂度是O(n) * O(4^n / n^1.5) = O(4^n / n^0.5)。

因此,该算法的时间复杂度是O(n^3),空间复杂度是O(4^n / n^0.5)。

五、总结知识点

  1. 递归:代码中使用了递归函数generateSubtrees来生成所有可能的二叉搜索树。递归是一种常用的算法设计技巧,它允许函数调用自身来解决问题的一个较小部分,直到达到一个基准情况。

  2. 二叉搜索树(BST)的性质:二叉搜索树是一种特殊的二叉树,其中每个节点的值都大于其左子树的所有节点的值,且小于其右子树的所有节点的值。代码中利用了这个性质来生成所有可能的BST。

  3. 列表(List)的使用:Java中的List接口用于存储有序的集合,代码中使用了ArrayList来实现这个接口。列表用于存储生成的子树和最终的树集合。

  4. 循环和条件语句:代码中使用了for循环来遍历可能的根节点值,并使用了if语句来判断递归的基准情况。

  5. 树的结构:代码中定义了TreeNode类来表示树的节点,每个节点包含一个值和指向其左右子节点的引用。

  6. 动态规划思想:虽然代码中没有显式地使用动态规划,但是递归方法中隐含了动态规划的思想,即通过解决子问题来构建整个问题的解决方案,并且存储这些子问题的解以避免重复计算。

  7. 函数定义和返回值:代码中定义了两个函数:generateTrees是公共接口,generateSubtrees是私有辅助函数。generateSubtrees函数返回一个包含所有可能的子树的列表。

  8. 空树的处理:在递归的基准情况中,代码添加了一个空树(null)到子树列表中。这表示没有更多的节点可以用来构建树,是递归终止的条件。

  9. 组合问题的解决:代码通过两层循环来组合左子树和右子树,这是一种常见的解决组合问题的方法。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/837133.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity自定义动画-Animation动画数据-How is “fileIDToRecycleName“ generated

一般美术和程序分工明确的项目 fbx确实是和动画一一对应的&#xff1b; 但一些独立&#xff0c;或者小工作室的项目&#xff0c;就没法保证了&#xff0c;关键还是在于 Unity的 .meta 目录 查找和对比了一下 .fbx 和 .meta&#xff1a; 缓存和不缓存Animation 具体的Animat…

HCIP-Datacom-ARST自选题库_03_VLAN【26道题】

一、单选题 1.QinQ技术是一项扩展VLAN空间的技术&#xff0c;通过在802.1Q标签报文的基础上再增加一层802.1Q的Tag来达到扩展VLAN空间的功能。下列关于QinQ说法错误的是 灵活QinQ可以根据不同的内层Tag而加上不同的外层Tag&#xff0c;对于用户VLAN的划分更加细致 QinQ使VLA…

Golang | Leetcode Golang题解之第86题分隔链表

题目&#xff1a; 题解&#xff1a; func partition(head *ListNode, x int) *ListNode {small : &ListNode{}smallHead : smalllarge : &ListNode{}largeHead : largefor head ! nil {if head.Val < x {small.Next headsmall small.Next} else {large.Next hea…

ue引擎游戏开发笔记(39)——npc的ai设定:追踪玩家以及瞄准

1.需求分析&#xff1a; 实现对npc的击杀和死亡反馈后&#xff0c;下一步需要赋予npc基本的ai&#xff0c;首先就是敌人要能够追踪或者说跟随玩家&#xff0c;这才能为后续npc开枪&#xff0c;对射做好准备&#xff0c;首先实现追踪玩家。 2.操作实现&#xff1a; 1.思路&…

2024.5组队学习——MetaGPT智能体理论与实战(待续)

学习资料&#xff1a;项目地址——hugging-multi-agent、在线阅读、MetaGPT项目、MetaGPT中文文档 文章目录 一、环境配置1.1 配置MetaGPT1.2 配置大模型api_key1.3 测试demo 一、环境配置 全部工作在Autodl上完成&#xff0c;下面是简单记录&#xff1a; 1.1 配置MetaGPT 下…

不好!有敌情,遭到XSS攻击【网络安全篇】

XSS&#xff1a;当一个目标的站点&#xff0c;被我们用户去访问&#xff0c;在渲染HTMl的过程中&#xff0c;出现了没有预期到的脚本指令&#xff0c;然后就会执行攻击者用各种方法注入并执行的恶意脚本&#xff0c;这个时候就会产生XSS。 涉及方&#xff1a; 用户&#xff0…

前端铺子-uniapp移动端:跨平台开发新篇章

一、引言 在移动应用开发领域&#xff0c;随着技术的不断进步&#xff0c;用户对应用的需求也日益多样化。如何快速、高效地开发跨平台应用成为了前端开发者面临的一大挑战。uni-app作为一款使用Vue.js开发所有前端应用的框架&#xff0c;凭借其一次编写、多端运行的特性&…

Vue Excel 文件流导出乱码快速解决方案

今日在开发一个导出功能&#xff0c;原本一个非常简单的功能&#xff0c;却没想里面藏了陷阱&#xff01; 背景 前端导出的文件流乱码&#xff0c;此时确定非后端问题&#xff08;可以在postman导出是否正常来判断&#xff09;。 前端导出&#xff1a; 后端正常数据&#xf…

Nature 综述(IF=88):微生物群落和土壤性质之间的相互作用

随着社会的发展&#xff0c;环境污染和自然资源的消耗日益严重&#xff0c;土壤生态系统的健康状况备受关注。然而&#xff0c;当前研究领域存在一个问题&#xff0c;即在研究土壤微生物群落结构的同时&#xff0c;忽略了微生物对土壤环境的影响。本文旨在探讨微生物如何通过生…

【树】简要理解树的概念

P. S.&#xff1a;以下代码均在VS2019环境下测试&#xff0c;不代表所有编译器均可通过。 P. S.&#xff1a;测试代码均未展示头文件stdio.h的声明&#xff0c;使用时请自行添加。 目录 1、树的概念2、树的相关概念3、结语 1、树的概念 树是一种非线性的数据结构&#xff0c;它…

C#语言进阶

一、简单数据结构类 1. ArrayList ArrayList是一个 C# 为我们封装好的类&#xff0c;它的本质是一个 object 类型的数组。ArrayList类帮助我们实现了很多方法&#xff0c;比如数组的增删查改 1.1 声明 using System.Collections;ArrayList array new ArrayList(); 1.2 增…

利用光学和SAR数据进行亚马逊热带雨林监测

亚马逊热带雨林&#xff0c;670万平方公里&#xff0c;物种丰富&#xff0c;森林历史悠久。巴西环保局用光学和SAR数据进行森林监测&#xff0c;主要监测森林砍伐范围、人为破坏、非法采矿和隐蔽的飞机跑道。 图 2011年12月森林砍伐范围 在SAR强度数据上&#xff0c;被砍伐的森…

Java 实现Mybatis plus 批量删除

数据库实体字段并不映射的情况&#xff0c;直接请求体集合接收。 PostMapping("/removeIdsInfo")public R<Void> removeIdsInfo(RequestBody List<Integer> ids) {return exStudentService.removeIdsInfo(ids);} /**** 学生模块根据集合id 批量删除数据*…

HUE工具介绍使用

一、HUE工具介绍使用 HUE是CDH提供一个hive和hdfs的操作工具&#xff0c;在hue中编写了hiveSQl也可以操作hdfs的文件 http://hadoop01:9870 hdfs的web访问端口 hdfs://hadoop01:8020 hdfs的程序访问端口 进入hue

【Linux】了解信号产生的五种方式

文章目录 正文前的知识准备kill 命令查看信号man手册查看信号信号的处理方法 认识信号产生的5种方式1. 工具2. 键盘3. 系统调用kill 向任意进程发送任意信号raise 给调用方发送任意信号abort 给调用方发送SIGABRT信号 4. 软件条件5. 异常 正文前的知识准备 kill 命令查看信号 …

虚拟机桥接模式连接失败解决方案

问题&#xff1a; 虚拟机之前使用一直没有问题&#xff0c;某次开机后不能正常使用桥接模式了&#xff0c;确认防火墙等相关都已关闭设置好。 解决方案&#xff1a; 添加新的网络适配器后&#xff0c;改成桥接模式&#xff0c;然后保存后重新打开&#xff0c;可以正常使用

Ubuntu22.04怎么安装cuda11.3

环境&#xff1a; WSL2 Ubuntu22.04 问题描述&#xff1a; Ubuntu22.04怎么安装cuda11.3 之前是11.5 解决方案&#xff1a; 在Ubuntu 22.04上安装CUDA 11.3需要一些步骤&#xff0c;因为CUDA 11.3不是为Ubuntu 22.04官方支持的版本。但是&#xff0c;您仍然可以通过以下步…

“圣诞树图案的打印~C语言”

圣诞树图案的打印~C语言 题目原文&#xff1a;[圣诞树](https://www.nowcoder.com/practice/9a03096ed8ab449e9b10b0466de29eb2?tpId107&rp1&ru/ta/beginner-programmers&qru/ta/beginner-programmers/question-ranking&difficulty&judgeStatus&tags&…

运维安全管理系统:“四集中”管理 解决迫切问题

日前&#xff0c;国内专注于保密与非密领域的分级保护、等级保护、业务连续性安全和大数据安全产品解决方案与相关技术研究开发的领军企业——国联易安依托自身强大的研发能力&#xff0c;丰富的行业经验&#xff0c;自主研发了新一代软硬件一体化统一安全运维平台——国联易安…

【单片机调试】mcu调试bug记录

【单片机调试】mcu调试bug记录 2023.5-2023.11待输入 2023.12-2023.22024.3-至今1.spi通信问题 2023.5-2023.11 待输入 2023.12-2023.2 辞职阶段&#xff1a;【STM32调试】寄存器调试不良问题记录持续版 2024.3-至今 1.spi通信问题 现象说明&#xff1a; mcu与afe芯片为spi通…