打印括号的有效组合

2017-07-05  本文已影响0人  chappie2017

题目

输入n,表示有n/2个左括号,n/2个右括号
打印出这n个括号的有效组合

解法

深度优先搜索+

#include <iostream>

void print_result(int A[], int n , int cur){
    if(A==NULL || n<1 || cur<0 || cur>=n)
        return;
    if(A[0]==0)
        std::cout<<"{"<<std::flush;
    else
        std::cout<<"}"<<std::flush;
    for(int i=1; i<cur ; ++i){
        if(A[i]==0)
            std::cout<<" {"<<std::flush;
        else
            std::cout<<" }"<<std::flush;
    }
    for(int i=cur ; i< n ; ++i)
        std::cout<<" }"<<std::flush;
    std::cout<<std::endl;
}
long long count;
void dfs(int A[], int n, int rem, int stack_ , int cur){
    if(A==NULL || n<1 ||rem<0 || stack_<0 || cur<0 || cur>n)
        return;
    if(rem==0){
        print_result(A, n, cur);
        return;
    }
    A[cur]=0;
    dfs(A, n, rem-1, stack_+1, cur+1);
    A[cur]=1;
    dfs(A, n, rem, stack_-1, cur+1);
}

void print(int n){
    if( n<0 || n%2)
        return;
    int *A=new int[n];
    dfs(A, n, n/2, 0, 0);
    delete[] A;
}

int main()
{
    int n;
    bool blanc=false;
    while(std::cin>>n){
        if(blanc)
            std::cout<<std::endl;
        if(n==0)
            break;
        count=0;
        print(n);
        blanc=true;
    }
    return 0;
}

如果不要求打印输出,只是求出有多少个组合,那么就可以使用递推公式:
f(0)=1
f(n)=f(0)f(n-2)+f(2)f(n-1)+...+f(n-2)*f(0)

long long total_(int n){
    if(n<=0 || n%2)
        return 0;
    int *A = new int[n/2+1];
    A[0]=1;
    long long total;
    for(int i=1 ; i<n/2+1 ; ++i){
        total=0;
        for(int j=0 ; j<i/2; ++j){
            total=total+2*A[j]*A[i-1-j];
        }
        if( i%2 )
            total+=A[i/2]*A[i/2];
        A[i]=total;
    }
    delete[] A;
    return total;
}
上一篇 下一篇

猜你喜欢

热点阅读