美文网首页
打印括号的有效组合

打印括号的有效组合

作者: chappie2017 | 来源:发表于2017-07-05 10:49 被阅读0次

    题目

    输入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;
    }
    

    相关文章

      网友评论

          本文标题:打印括号的有效组合

          本文链接:https://www.haomeiwen.com/subject/pynfhxtx.html