题解 | #括号生成#
括号生成
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);
}
}
查看2道真题和解析