95题-不同的二叉搜索树 II

1.1描述

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

1.2解答

这题主要参考的是leetcode高赞回答

1.3代码

public class Solution {
    public List<TreeNode> generateTrees(int n) {
        ArrayList<TreeNode>[] dp = new ArrayList[n + 1];
        dp[0] = new ArrayList<TreeNode>();
        if (n == 0) {
            return dp[0];
        }
        dp[0].add(null);
        //长度为 1 到 n
        for (int len = 1; len <= n; len++) {
            dp[len] = new ArrayList<TreeNode>();
            //将不同的数字作为根节点,只需要考虑到 len
            for (int root = 1; root <= len; root++) {
                //左子树的长度
                int left = root - 1;
                //右子树的长度
                int right = len - root;
                for (TreeNode leftTree : dp[left]) {
                    for (TreeNode rightTree : dp[right]) {
                        TreeNode treeRoot = new TreeNode(root);
                        treeRoot.left = leftTree;
                        //克隆右子树并且加上偏差
                        treeRoot.right = clone(rightTree, root);
                        dp[len].add(treeRoot);
                    }
                }
            }
        }
        return dp[n];
    }

    private TreeNode clone(TreeNode n, int offset) {
        if (n == null) {
            return null;
        }
        TreeNode node = new TreeNode(n.val + offset);
        node.left = clone(n.left, offset);
        node.right = clone(n.right, offset);
        return node;
    }

}
posted @ 2020-07-21 06:58  大嘤熊  阅读(108)  评论(0编辑  收藏  举报