码迷,mamicode.com
首页 > 其他好文 > 详细

lintcode: 生成括号

时间:2016-04-03 13:01:47      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:

 生成括号

给定 n 对括号,请写一个函数以将其生成新的括号组合,并返回所有组合结果。

样例

给定 n = 3, 可生成的组合如下:

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

解题

参考链接

采用递归树的思想,当左括号数大于右括号数时可以加左或者右括号,否则只能加左括号,当左括号数达到n时,剩下全部添加右括号

public class Solution {
    /**
     * @param n n pairs
     * @return All combinations of well-formed parentheses
     */
    public ArrayList<String> generateParenthesis(int n) {
        // Write your code here
        ArrayList<String> result  = new ArrayList<String>();
        if(n<=0)
            return result;
        int left = 0,right=0;
        String str="";
        generateParenthesis(n,left,right,str,result);
        return result;
    }
    public void generateParenthesis(int n,int left,int right,String str ,ArrayList<String> result){
        if(left == n){
            for(int i=0;i< n- right;i++)
                str+=")";
            result.add(str);
            return;
        }
        generateParenthesis(n, left+1, right,str+"(",result);  
        if(left>right){  
            generateParenthesis(n, left, right+1,str+")",result); 
        }  
    }
}

 

lintcode: 生成括号

标签:

原文地址:http://www.cnblogs.com/theskulls/p/5349547.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!