95. Unique Binary Search Trees II

recursion or dp

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public List<TreeNode> generateTrees(int n) {
        // start->end
        return recursion(1,n);
    }
    
    private List<TreeNode> recursion(int start, int end){
        List<TreeNode> list = new LinkedList<>();
        if (start>end){
            list.add(null);
            return list;
        }
        
        for(int i=start; i<=end; i++){
            List<TreeNode> leftList= recursion(start, i-1);
            List<TreeNode> rightList = recursion(i+1, end);
            for(TreeNode leftNode: leftList){
                for(TreeNode rightNode: rightList){
                    TreeNode node=new TreeNode(i);
                    node.left = leftNode;
                    node.right = rightNode;
                    list.add(node);
                }
            }
        }
        return list;
    }
}

Last updated

Was this helpful?