遍历的过程当中,每一个位置先尝试左括号,再尝试右括号 。
面试
void findParens(int l, int r, int& validCnt)
{
if(l > r){return;} //剩余的左括号大于了右括号,非法case
if(l ==0 ){ //剩余的左括号确定先被减小到0,剩余全是右括号
validCnt++;
return;
}
findParens(l-1,r,validCnt); //将当前位置赋值为左括号
findParens(l, r-1,validCnt);//将当前位置赋值为右括号
}
void testGenerateParens()
{
int pair=10;
int validCnt=0;
findParens(pair,pair,validCnt);
printf("%d\n",validCnt);
}spa