95. Unique Binary Search Trees II

Given an integer n, generate all structurally unique BST's (binary search trees) that store values 1...n.
For example,Given n = 3, your program should return all 5 unique BST's shown below.

  1         3     3     2       1 
   \\       /     /     /  \\      \\ 
   3     2      1     1    3       2 
   /    /        \\                  \\ 
  2    1          2                  3
/**
 * Definition for binary tree
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; left = null; right = null; }
 * }
 */
public class Solution {
    public List<TreeNode> generateTrees(int m, int n){
        List<TreeNode> ans = new LinkedList<TreeNode>();
        if(m > n){
            ans.add(null);
        }
        for(int i = m; i<=n; i++){
            List<TreeNode> leftTrees = generateTrees(m, i-1);
            List<TreeNode> rightTrees = generateTrees(i+1, n);
            for(TreeNode left: leftTrees){
                for(TreeNode right: rightTrees){
                    TreeNode root = new TreeNode(i);
                    root.left = left;
                    root.right = right;
                    ans.add(root);
                }
            }
        }
        return ans;
    }
    
    public List<TreeNode> generateTrees(int n) {
        return generateTrees(1, n);
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容