算法-求符合规范的括号集合
给出一组正括号、反括号,获取所有符合规范的集合 如 :两组括号集合有 (()),()()
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),可获取以下集合