题解 | #括号生成#

括号生成

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

先放左括号,每个右括号前面都要有一个没使用的左括号跟它抵消。
具体实现,回溯,设置一个标志位flag=0,表示左括号的数量。思想是放入左括号flag++,放入右括号flag--。如果flag小于0那么这个序列肯定已经不合法了,没有添加下去的必要了。这是因为每次放右括号都需要前面有一个没使用的左括号跟它抵消。flag小于0表示左括号已经被后来放入的右括号抵消完了,这次先放入了右括号(不合法)。
public class Solution {
    /**
     * 
     * @param n int整型 
     * @return string字符串ArrayList
     */
    public ArrayList<String> generateParenthesis (int n) {
        // write code here
        ArrayList<String> res=new ArrayList<>();
        StringBuffer str=new StringBuffer();
        process(res,str,2*n,0);
        return res;
    }
    public void process(ArrayList<String> res,StringBuffer str,int len,int flag){
        if(len<0||flag<0)return;//这里是出口,len<0要不然如果一值添加左括号。flag<0,序列已经不合法了,没有接下去添加的必要了
        if(len==0&&flag==0){
            res.add(new String(str));
        }
//         if(flag==0){
//             str.append("(");
//             process(res,str,len-1,flag+1);
//             str.deleteCharAt(str.length()-1);
//         }else if(flag>0){
//             str.append("(");
//             process(res,str,len-1,flag+1);
//             str.deleteCharAt(str.length()-1);
//             str.append(")");
//             process(res,str,len-1,flag-1);
//             str.deleteCharAt(str.length()-1);
//         }
        str.append("(");
        process(res,str,len-1,flag+1);
        str.deleteCharAt(str.length()-1);
        str.append(")");
        process(res,str,len-1,flag-1);
        str.deleteCharAt(str.length()-1);
    }
}
全部评论

相关推荐

joe2333:怀念以前大家拿华为当保底的日子
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务