当前位置: 首页 > news >正文

【改造后序遍历算法】95. 不同的二叉搜索树 II

95. 不同的二叉搜索树 II

解题思路

  • 遍历每一个节点
  • 查看以k为根节点的二叉搜索树
  • 储存所有左子树的根节点
  • 储存所有右子树的根节点
  • 将左子树和右子树组装起来 将根节点储存在向量中
/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode() {}*     TreeNode(int val) { this.val = val; }*     TreeNode(int val, TreeNode left, TreeNode right) {*         this.val = val;*         this.left = left;*         this.right = right;*     }* }*/
class Solution {public List<TreeNode> generateTrees(int n) {if(n < 1) return generate(1,0);return generate(1,n);}List<TreeNode> generate(int start,int end){List<TreeNode> subTree = new ArrayList<>();// 储存所有的根节点if(start > end){subTree.add(null);return subTree;}// 查找以k为根节点的二叉搜索树for(int k = start; k <= end; k++){// 储存所有左子树的根节点List<TreeNode> left = generate(start,k - 1);// 储存所有右子树的根节点List<TreeNode> right = generate(k + 1,end);// 将左子树和右子树组装起来  将根节点储存在向量中for(int i = 0; i < left.size(); i++){for(int j = 0; j < right.size(); j++){TreeNode root = new TreeNode(k);// 新建一个节点root.left = left.get(i);root.right = right.get(j);subTree.add(root);}}}return subTree;}
}
http://www.lryc.cn/news/181999.html

相关文章:

  • 栈的基本操作(数据结构)
  • D. Jellyfish and Mex Codeforces Round 901 (Div. 2)
  • 操作系统内存管理相关
  • Sui流动性质押黑客松获胜者公布,助力资产再流通
  • 为什么在使用PageHelper插件时,指定的每页记录数大小失效?显示所有的记录数
  • XML文档基础
  • 软考知识汇总-软件工程
  • 力扣:119. 杨辉三角 II(Python3)
  • 指针笔试题(带解析版)
  • 服务器搭建(TCP套接字)-libevent版(服务端)
  • 斐波那契模型系列【动态规划】
  • 【Java】微服务——Nacos注册中心
  • Redis Cluster Gossip Protocol: PING, PONG, MEET
  • httpserver 下载服务器demo 以及libevent版本的 httpserver
  • 构建强大的RESTful API:@RestController与@Controller的对比与应用
  • 【Java-LangChain:使用 ChatGPT API 搭建系统-10】评估(下)-当不存在一个简单的正确答案时
  • 【微服务的集成测试】python实现-附ChatGPT解析
  • Mesa新版来袭
  • 基于 SpringBoot 2.7.x 使用最新的 Elasticsearch Java API Client 之 ElasticsearchClient
  • 辅助驾驶功能开发-功能对标篇(15)-NOA领航辅助系统-吉利
  • javascript: Sorting Algorithms
  • 嵌入式Linux应用开发-驱动大全-同步与互斥④
  • 2023年【高压电工】证考试及高压电工复审模拟考试
  • C/C++学习 -- 分组密算法(3DES算法)
  • C/C++面试题总结
  • Java下正面解除警告Unchecked cast: ‘java.lang.Object‘ to ‘java.util.ArrayList‘
  • 图像处理与计算机视觉--第四章-图像滤波与增强-第二部分
  • [前端基础]typescript安装以及类型拓展
  • 网络参考资料汇总(1)
  • Remove和RemoveLast用法