开局先上题:
给出 n 代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。
例如,给出 n = 3,生成结果为:
[
"((()))",
"(()())",
"(())()",
"()(())",
"()()()"
]
原思路采用栈进行左括号0-N(固定),右括号动态从0~N。对于右括号进行位置排列从[1,N]
上述算法复杂度O(4N/sqrt(N)),下面介绍高明算法
思路是:
假定一个括号是必须的 " ( ) " 。那么下一个可以匹配括号对出现的位置必然是在上个括号中间或是右边(只有内外两种情况)。
设i+j=n
,则
"(" + 【i=p时所有括号的排列组合】 + ")" + 【i=q时所有括号的排列组合】
python实现如下:
class Solution:
def generateParenthesis(self, n: int) -> List[str]:
if n == 0:
return []
total_l = []
total_l.append([None]) # 0组括号时记为None
total_l.append(["()"]) # 1组括号只有一种情况
for i in range(2,n+1): # 开始计算i组括号时的括号组合
l = []
for j in range(i): # 开始遍历 p q ,其中p+q=n-1 , j 作为索引
now_list1 = total_l[j] # p = j 时的括号组合情况
now_list2 = total_l[i-1-j] # q = (i-1) - j 时的括号组合情况
for k1 in now_list1:
for k2 in now_list2:
if k1 == None:
k1 = ""
if k2 == None:
k2 = ""
el = "(" + k1 + ")" + k2
l.append(el) # 把所有可能的情况添加到 l 中
total_l.append(l) # l这个list就是i组括号的所有情况,添加到total_l中,继续求解i=i+1的情况
return total_l[n]