算法-求符合规范的括号集合

算法-求符合规范的括号集合

给出一组正括号、反括号,获取所有符合规范的集合 如 :两组括号集合有 (()),()()

package com.util;

import java.util.ArrayList;
import java.util.List;

/**
*((((( ))))) 符合规范的集合  
 */
public class BracketAlg {

    //((((( ))))) 符合规范的集合
    public static void main(String[] args) {
        getList(10);
    }

    private static List<String> getList(int count) {
        List<String> list = new ArrayList<>();
        long sumAmt = 1;
        for (int i=0;i< count; i++ ) {
            sumAmt  = sumAmt << 1;
        }
        sumAmt--;
        for (long i =0;i<sumAmt; i++) {
            String tmp = Long.toBinaryString(i);
            int len = tmp.length();
            if (len < count) {
                for (int j=0;j<count-len;j++){
                    tmp = "0" + tmp;
                }
            }
            if(checktmp(tmp)){
                System.out.println(tmp.replaceAll("0", "(").replaceAll("1", ")"));
                list.add(tmp);
            }

        }
        System.out.println(list.size());
        return list;
    }

    private static boolean checktmp(String tmp) {
        if (tmp.length() == 0) {
            return true;
        }
        int last0 = tmp.lastIndexOf("0");
        if (last0 <0 ||last0 == tmp.length()-1) {
            return false;
        }
        int first1= tmp.substring(last0+1).indexOf("1");
        if (first1 < 0) {
            return false;
        }
        tmp = tmp.substring(0, last0) + tmp.substring(last0+2);
        return checktmp(tmp);
    }
}


验证下,六个字符 getList(6),可获取以下集合
在这里插入图片描代付述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值