遍歷的過程當中,每一個位置先嚐試左括號,再嘗試右括號 。
面試
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