95.不同的二叉搜索树Ⅱ python

不同的二叉搜索树Ⅱ

题目

题目描述

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

示例 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

题解

为了生成所有由 n 个节点组成且节点值从 1 到 n 互不相同的不同二叉搜索树(BST),我们可以使用递归和回溯的方法。这个问题可以通过递归地选择每个可能的根节点,然后分别构建左子树和右子树来解决。

解题思路

对于范围 [1, n] 中的每一个数 i,我们可以把它作为当前树的根节点,那么:

  • 所有可能的左子树是通过递归调用 [1, i-1] 获得的。
  • 所有可能的右子树是通过递归调用 [i+1, n] 获得的。

我们将这两个结果集合并,并将每一对左子树和右子树与当前根节点组合起来,形成一个完整的二叉搜索树。

Python 实现代码

首先,定义一个辅助函数来生成指定范围内所有可能的二叉搜索树。然后,在主函数中调用这个辅助函数并传入初始参数。

python 复制代码
def generateTrees(n: int):
    if n == 0:
        return []
    
    def generate_trees(start, end):
        if start > end:
            return [None,]
        
        all_trees = []
        for i in range(start, end + 1):  # 尝试每个数字作为根节点
            # 获取所有可能的左子树
            for left in generate_trees(start, i - 1):
                # 获取所有可能的右子树
                for right in generate_trees(i + 1, end):
                    # 创建当前树并加入到列表
                    current_tree = TreeNode(i)
                    current_tree.left = left
                    current_tree.right = right
                    all_trees.append(current_tree)
        
        return all_trees
    
    return generate_trees(1, n)

注意事项

  • n = 0 时,没有节点可以用来构建树,因此返回空列表。
  • 使用了深度优先搜索(DFS)的思想,通过递归来遍历所有可能性。
  • 该算法的时间复杂度较高,因为对于每一个节点都要考虑它作为根节点的情况,并递归处理其左右子树。但是由于题目限制了 1 <= n <= 8,这种方法在实际应用中是可行的。

提交结果

相关推荐
2301_765703141 天前
C++中的职责链模式实战
开发语言·c++·算法
编程彩机1 天前
互联网大厂Java面试:从分布式缓存到消息队列的技术场景解析
java·redis·面试·kafka·消息队列·微服务架构·分布式缓存
StandbyTime1 天前
《算法笔记》学习记录-第一章
c++·算法·算法笔记
我的xiaodoujiao1 天前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 44--将自动化测试结果自动推送至钉钉工作群聊
前端·python·测试工具·ui·pytest
沈浩(种子思维作者)1 天前
铁的居里点(770度就不被磁铁吸了)道理是什么?能不能精确计算出来?
人工智能·python·flask·量子计算
yufuu981 天前
使用Scikit-learn进行机器学习模型评估
jvm·数据库·python
近津薪荼1 天前
优选算法——双指针8(单调性)
数据结构·c++·学习·算法
f狐0狸x1 天前
【C++修炼之路】C++ list容器基本用法详解
开发语言·c++·list
松☆1 天前
Dart 中的常用数据类型详解(含 String、数字类型、List、Map 与 dynamic) ------(2)
数据结构·list
格林威1 天前
Baumer相机铆钉安装状态检测:判断铆接是否到位的 5 个核心算法,附 OpenCV+Halcon 的实战代码!
人工智能·opencv·算法·计算机视觉·视觉检测·工业相机·堡盟相机