LeetCode:95. 不同的二叉搜索树 II

class Solution {

public:

vector<TreeNode*> generateTrees(int n) {

if(n==0){

return vector<TreeNode*>{};

}

return build(1,n);

}

vector<TreeNode*>build(int lo,int hi){

vector<TreeNode*>res;

if(lo>hi){

res.emplace_back(nullptr);

return res;

}

for(int i=lo;i<=hi;i++){

vector<TreeNode*> leftTree=build(lo,i-1);

vector<TreeNode*> rightTree=build(i+1,hi);

for(auto left:leftTree){ //自动匹配类型

for(auto right:rightTree){

TreeNode* root=new TreeNode(i);

root->left=left;

root->right=right;

res.emplace_back(root);

}

}

}

return res;

}

};

相关推荐
前端炒粉15 小时前
35.LRU 缓存
开发语言·javascript·数据结构·算法·缓存·js
断剑zou天涯17 小时前
【算法笔记】窗口内最大值或最小值的更新结构
java·笔记·算法
smj2302_7968265217 小时前
解决leetcode第3753题范围内总波动值II
python·算法·leetcode
骑着猪去兜风.19 小时前
线段树(二)
数据结构·算法
fengfuyao98520 小时前
竞争性自适应重加权算法(CARS)的MATLAB实现
算法
散峰而望20 小时前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github
leoufung20 小时前
LeetCode 92 反转链表 II 全流程详解
算法·leetcode·链表
靠沿20 小时前
Java数据结构初阶——Collection、List的介绍与ArrayList
java·数据结构·list
wyhwust21 小时前
交换排序法&冒泡排序法& 选择排序法&插入排序的算法步骤
数据结构·算法·排序算法
利刃大大21 小时前
【动态规划:背包问题】完全平方数
c++·算法·动态规划·背包问题·完全背包