【leetcode 刷题日记】23-不同的二叉搜索树 II(C++)

不同的二叉搜索树 II

题目

给定一个整数 n,生成所有由 1 … n 为节点所组成的二叉搜索树。

示例

输入: 3 输出: [ [1,null,3,2], [3,2,null,1], [3,1,null,null,2],
[2,1,3], [1,null,2,null,3] ] 解释: 以上的输出对应以下 5 种不同结构的二叉搜索树:

思路

我们将i作为根节点,1到i-1作为左子树,i+1到n作为右子树,然后递归地产生树,最后生成树。

代码

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    vector<TreeNode*> helper(int start,int end){
        vector<TreeNode*> ret;
        if(start > end)
            ret.push_back(nullptr);
        
        for(int i=start;i<=end;i++){
            vector<TreeNode*> left = helper(start,i-1);
            vector<TreeNode*> right = helper(i+1,end);
            for(auto l : left){
                for(auto r : right){
                    TreeNode* root = new TreeNode(i);
                    root -> left = l;
                    root -> right = r;
                    ret.push_back(root);
                }
            }
        }
        return ret;
    }
    
    vector<TreeNode*> generateTrees(int n) {
        vector<TreeNode*> ret;
        if(n == 0)
            return ret;    
        ret = helper(1,n);
        return ret;
    }
};

发布了34 篇原创文章 · 获赞 24 · 访问量 1996

猜你喜欢

转载自blog.csdn.net/fengshiyu1997/article/details/105055005
今日推荐