【LeetCode】 95. Unique Binary Search Trees II 不同的二叉搜索树 II(Medium)(JAVA)
题目地址: https://leetcode.com/problems/unique-binary-search-trees-ii/
题目描述:
Given an integer n, generate all structurally unique BST’s (binary search trees) that store values 1 … n.
Example:
Input: 3
Output:
[
[1,null,3,2],
[3,2,null,1],
[3,1,null,null,2],
[2,1,3],
[1,null,2,null,3]
]
Explanation:
The above output corresponds to the 5 unique BST's shown below:
1 3 3 2 1
\ / / / \ \
3 2 1 1 3 2
/ / \ \
2 1 2 3
题目大意
给定一个整数 n,生成所有由 1 … n 为节点所组成的二叉搜索树。
解题方法
1、以 1 ~ n 某一个节点 k 为父节点,左边 1 ~ (k - 1) 为 二叉搜索树,右边 (k + 1) ~ n 也为二叉搜索树
2、不点递归即可找出所有的二叉搜索树
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public List<TreeNode> generateTrees(int n) {
return gH(1, n);
}
public List<TreeNode> gH(int start, int end) {
List<TreeNode> res = new ArrayList<>();
if (start > end) return res;
if (start == end) {
res.add(new TreeNode(start));
return res;
}
for (int i = start; i <= end; i++) {
List<TreeNode> left = gH(start, i - 1);
List<TreeNode> right = gH(i + 1, end);
if (left.size() == 0 && right.size() == 0) {
TreeNode node = new TreeNode(i);
res.add(node);
} else if (left.size() == 0) {
for (int j = 0; j < right.size(); j++) {
TreeNode node = new TreeNode(i);
node.right = right.get(j);
res.add(node);
}
} else if (right.size() == 0) {
for (int j = 0; j < left.size(); j++) {
TreeNode node = new TreeNode(i);
node.left = left.get(j);
res.add(node);
}
} else {
for (int j = 0; j < right.size(); j++) {
for (int k = 0; k < left.size(); k++) {
TreeNode node = new TreeNode(i);
node.left = left.get(k);
node.right = right.get(j);
res.add(node);
}
}
}
}
return res;
}
}
执行用时 : 1 ms, 在所有 Java 提交中击败了 99.94% 的用户
内存消耗 : 40 MB, 在所有 Java 提交中击败了 14.29% 的用户