给出 n 表明生成括号的对数,请你写出一个函数,使其可以生成全部可能的而且有效的括号组合。python
例如,给出 n = 3,生成结果为:app
[ "((()))", "(()())", "(())()", "()(())", "()()()" ]
回溯法函数
python能够函数里定义函数spa
class Solution(object): def generateParenthesis(self, N): ans = [] def backtrack(S = '', left = 0, right = 0): if len(S) == 2 * N: ans.append(S) return if left < N: backtrack(S+'(', left+1, right) if right < left: backtrack(S+')', left, right+1) backtrack() return ans