164. Unique Binary Search Trees II
中文English
Given n, generate all structurally unique BST's (binary search trees) that store values 1...n.
Example
Example 1:
Input:3
Output:
1 3 3 2 1
\ / / / \ \
3 2 1 1 3 2
/ / \ \
2 1 2 3
解法1:DFS递归。
代码如下:
/**
* Definition of TreeNode:
* class TreeNode {
* public:
* int val;
* TreeNode *left, *right;
* TreeNode(int val) {
* this->val = val;
* this->left = this->right = NULL;
* }
* }
*/
class Solution {
public:
/**
* @paramn n: An integer
* @return: A list of root
*/
vector<TreeNode *> generateTrees(int n) {
return helper(1, n);
}
private:
vector<TreeNode *> helper(int begin, int end) {
if (begin > end) return vector<TreeNode *>{NULL};
vector<TreeNode *> result;
for (int i = begin; i <= end; ++i) {
vector<TreeNode *> leftTree = helper(begin, i - 1);
vector<TreeNode *> rightTree = helper(i + 1, end);
for (int j = 0; j < leftTree.size(); ++j) {
for (int k = 0; k < rightTree.size(); ++k) {
TreeNode * node = new TreeNode(i);
node->left = leftTree[j];
node->right = rightTree[k];
result.push_back(node);
}
}
}
return result;
}
};
本文探讨了如何生成所有可能的、结构上独一无二的二叉搜索树,这些树存储从1到n的值。通过使用深度优先搜索(DFS)递归方法,详细解释并提供了实现代码,展示了如何为给定的整数n生成所有不同的二叉搜索树。
455

被折叠的 条评论
为什么被折叠?



