【LeetCode with Python】 Generate Parentheses

博客域名: http://www.xnerv.wang
原题地址: https://oj.leetcode.com/problems/generate-parentheses/
题目类型:递归,回溯
难度评价:★★
本文地址: http://blog.csdn.net/nerv3x3/article/details/2920102

Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses.

For example, given n = 3, a solution set is:

"((()))", "(()())", "(())()", "()(())", "()()()"


常见的递归回溯题目,要求左右括号匹配出现。只要符合一个规则即可认为是匹配:从左往右遍历时,左括号的数量>=右括号的数量。因此,每一层递归时,有两种分支选择:添加左括号,或者添加右括号。某一个分支能否继续,取决于是否符合上述规则。
代码中的left_count是记录当前层次递归时已经出现过的左括号数,left_remain是记录可供“消耗”的左括号数,即当前左括号数减去右括号数。Python的两个列表相加,表示将两个子列表合并成一个列表,如[1, 2] + [3] = [1, 2, 3]。

class Solution:

    def doGenerateParenthesis(self, n, left_count, left_remain, prefix):

        # only one out-point: the string has been finished.
        if n == left_count and 0 == left_remain:
            return [ prefix ]

        left_list = [ ]
        right_list = [ ]
        if left_count < n:
            left_list = self.doGenerateParenthesis(n, left_count + 1, left_remain + 1, prefix + "(")
        if left_remain > 0:
            right_list = self.doGenerateParenthesis(n, left_count, left_remain - 1, prefix + ")")

        return left_list + right_list

    # @param an integer
    # @return a list of string
    def generateParenthesis(self, n):
        if 0 == n:
            return [ ]
        else:
            list = self.doGenerateParenthesis(n, 0, 0, "")
            return list
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值