用分治递归生成所有合法的二叉搜索树: 在区间[left, right],我们依次选每个值i作为根节点,递归生成左子树区间和右子树区间的所有可能结构,再将左、右子树的所有组合与根节点拼接,得到当前区间的所有二叉搜索树。 class Solution { public: vector<TreeNode*> generateTrees(int n) { return dfs(1, n); // 从区间[1,n]开始递归 } // 生成区间[left, right]对应的所有二叉搜索树 vector<TreeNode*> dfs(int left, int right) { i...