算法提高之LeetCode刷题Leetcode模拟面试Leetcode

LeetCode-22 括号生成

2019-06-06  本文已影响1人  编程半岛

今天我们学习第22题括号生成,这是一道中等题。像这样字符串的题目经常作为面试题来考察面试者算法能力和写代码能力,因此最好能手写出该题。下面我们看看这道题的题目描述。

题目描述

给出n代表生成括号的对数,请你写出一个函数,使其能够生成所有可能的并且有效的括号组合。

例如,给出n = 3,生成结果为:

[
  "((()))",
  "(()())",
  "(())()",
  "()(())",
  "()()()"
]

分析

这个题是递归方面的题,对于递归不太熟悉的小伙伴可以扫描文章下方的二维码,关注『 算法半岛』回复『 数据结构目录』,即可获得相关学习资料。

对于递归的问题,我们需要明白以下三点:

上述分析所对应的java代码如下所示:

class Solution {
    
    public List<String> generateParenthesis(int n) {
        List<String> res = new ArrayList<String>();
        helper(n, n, "", res);
        return res;
    }
    
    // 递归辅助函数
    private void helper(int left, int right, String out, List<String> res){
        // 递归终止条件
        if (left < 0 || right < 0 || left > right)
            return ;
        // 当left和right都为0时,保存有效的括号组
        if(left == 0 && right == 0){
            res.add(out);
            return ;
        }
        
        // 减小问题的规模
        helper(left-1, right, out + "(", res);
        helper(left, right-1, out + ")",res);
    }
}

提交结果

Github地址

LeetCode-22 括号生成

参考链接

括号生成

更多文章,请扫描二维码关注『算法半岛』
上一篇 下一篇

猜你喜欢

热点阅读