题解 | #括号生成#

括号生成

https://www.nowcoder.com/practice/c9addb265cdf4cdd92c092c655d164ca

#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param n int整型 
# @return string字符串一维数组
#
class Solution:
    def generateParenthesis(self , n: int) -> List[str]:
        # write code here
        res = []

        def recur(temp, nleft, nright):
            # 记录前面使用了多少左括号,右括号
            if nleft == n:
                temp += ')'*(n-nright)
                res.append(temp)
                return  # 递归函数一定要记得终止条件的return!
            if nleft > nright:
                # 这里不需要for,而且因为是str,在传入函数的时候改变,所以不需要自己再改变
                recur(temp+'(', nleft+1, nright)
                recur(temp+')', nleft, nright+1)
            elif nleft == nright:
                recur(temp+'(', nleft+1, nright)
        recur('', 0, 0)
        return res

全部评论

相关推荐

在笔试的大西瓜很矫健:校招数分不用想了,这经历和学历都不够用,大厂更别想,初筛都过不了,说点不好听的小厂数分都进不去(小厂也是假数分),要两个对口实习+3个项目(或者3+2),而且要有含金量才能补一点你的学历劣势。 建议刷实习,社招找数分,校招看运气,能入行业就行,可以运营转数分
点赞 评论 收藏
分享
对空六翼:你真幸运,碰见这么好的人,不像我,秋招的时候被室友骗进cx了
实习好累,可以辞职全力准...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务