题目
数字 n
代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 **有效的 **括号组合。
有效括号组合需满足:左括号必须以正确的顺序闭合。
解题思路
可以用 dp
,横轴表示 (
,纵轴表示 )
,dp[i][j]
可以由 dp[i - 1][j]
和 dp[i][j - 1]
更新得到,懒得写。这题我用的递归,左括号没有限制条件,所以每次递归都可以添加左括号,只有当剩余左括号数量小于剩余右括号数量的时候才能添加右括号,这就是递归的过程。
代码
class Solution {
public void dfs(List<String> ans, String now, int left, int right) {
if (left + right == 0) {
ans.add(now);
return;
}
if (left > 0) dfs(ans, now + "(", left - 1, right);
if (left < right && right > 0) dfs(ans, now + ")", left, right - 1);
}
public List<String> generateParenthesis(int n) {
List<String> ans = new ArrayList<>();
dfs(ans, "", n, n);
return ans;
}
}