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;

}

};

相关推荐
zsc_1182 分钟前
pvz3解码小游戏求解算法 (二)
算法
菜_小_白3 分钟前
RTP协议收发组件开发
linux·网络·c++
jf加菲猫7 分钟前
第12章 数据可视化
开发语言·c++·qt·ui
hanbr10 分钟前
每日一题day1(Leetcode 76最小覆盖子串)
算法·leetcode
AI科技星12 分钟前
张祥前统一场论中两个电荷定义的统一性解析
开发语言·线性代数·算法·数学建模·平面
代码地平线12 分钟前
C语言实现堆与堆排序详解:从零手写到TopK算法及时间复杂度证明
c语言·开发语言·算法
小江的记录本13 分钟前
【大语言模型】大语言模型——核心概念(预训练、SFT监督微调、RLHF/RLAIF对齐、Token、Embedding、上下文窗口)
java·人工智能·后端·python·算法·语言模型·自然语言处理
炘爚14 分钟前
LeetCode(两两交换链表中的节点)
算法·leetcode·链表
wsoz15 分钟前
Leetcode矩阵-day7
c++·算法·leetcode·矩阵
念越15 分钟前
算法每日一题 Day01|双指针解决移动零问题
java·算法·力扣