我认为最简单的解决方案是处理输入字符串char-by-char:
public static List<String> split(String input) { int nParens = 0; int start = 0; List<String> result = new ArrayList<>(); for(int i=0; i<input.length(); i++) { switch(input.charAt(i)) { case ',': if(nParens == 0) { result.add(input.substring(start, i)); start = i+1; } break; case '(': nParens++; break; case ')': nParens--; if(nParens < 0) throw new IllegalArgumentException("Unbalanced parenthesis at offset #"+i); break; } } if(nParens > 0) throw new IllegalArgumentException("Missing closing parenthesis"); result.add(input.substring(start)); return result;}
例:
split("one,two,3,(4,five),six,(seven),(8,9,ten),eleven,(twelve,13,14,fifteen)") ->[one, two, 3, (4,five), six, (seven), (8,9,ten), eleven, (twelve,13,14,fifteen)]
作为免费赠品,此解决方案还根据需要计算嵌套括号:
split("one,two,3,(4,(five,six),seven),eight") ->[one, two, 3, (4,(five,six),seven), eight]
它还检查括号是否平衡(每个开放的括号都有相应的结束符)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)