• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-19  評論-1  文章-0  trackbacks-0
                    每個符號三角形都是由它的第一行“+,-”號分布決定的,據此可演算出所有分布的三角形,對其進行統計即可。

                    同時將一個n行三角形T+-號個數分別記為pos_num(n),neg_num(n),其第一行中的+,-號個數記為x(n),y(n),則可得到下式:

                    pos_num(n)=x(n)+pos_num(n-1)

                    neg_num(n)=y(n)+neg_num(n-1)

                    由此,我們可以從n=1開始,利用前面n=k-1的結果,迭代求出n=k的分布情形,然后對n=k的所有分布統計。

            #include<iostream>
            #include
            <vector>
            #include
            <cmath>
            using namespace std;
            struct record{
                
            int pos,neg;
                record(
            int a,int b){
                    pos
            =a;  neg=b;
                }

            }
            ;
            int main()
            {
                
            int n,i,j,k,sum;vector<record> v;
                
            for(int m=1;m<=24;m++)
                
            {
                    n
            =m;
                    
            if((n*(n+1))%4!=0){
                        cout
            <<n<<" 0"<<endl;
                        
            continue;
                    }

                    vector
            <record> v;
                    record r1(
            0,1);//n=1的情況
                    v.push_back(r1);
                    record r2(
            1,0);
                    v.push_back(r2);
                    
            for(i=2;i<=n;i++)//計算到n的所有情況
                    {
                        
            int * trip=new int[i];
                        
            int sum_i=(int)pow(2.0,i*1.0);
                        
            for(j=0;j<sum_i;j++)//第j種分布
                        {
                            
            int temp1=j, temp2=i;
                            
            int x=0,  y=0//記錄+,-的個數
                            while(temp1)
                            
            {
                                
            if(temp1%2==0){
                                    trip[
            --temp2]=0; y++;
                                }

                                
            else {
                                    trip[
            --temp2]=1;  x++;
                                }

                                temp1
            /=2;
                            }

                            
            for(k=0;k<temp2;k++)
                                y
            ++,  trip[k]=0;
                            
            int idx=0;
                            
            for(k=0;k<i-1;k++)
                            
            {
                                
            if(trip[k]+trip[k+1]==1)
                                    idx
            *=2;
                                
            else   idx*=2,idx+=1;
                            }

                            x
            +=v[2*((int)pow(2.0,i-2.0)-1)+idx].pos;
                            y
            +=v[2*((int)pow(2.0,i-2.0)-1)+idx].neg;
                            record r(x,y);
                            v.push_back(r);    
                        }

                        
                    }

                    
            /*if(n==3){
                        int star=2*((int)pow(2.0,n-1.0)-1);
                        for(j=0;j<(int)pow(2.0,n*1.0);j++)
                            printf("---%d %d\n",v[star+j].pos,v[star+j].neg);
                    }
            */

                    
            int base=2*((int)pow(2.0,n-1.0)-1);
                    
            int num=(int)pow(2.0,n*1.0);
                    sum
            =0;
                    
            for(i=0;i<num;i++){
                        
            if(v[base+i].pos==v[base+i].neg)
                            sum
            ++;
                    }

                    cout
            <<n<<" "<<sum<<endl;
                }

                
            return 0;
            }

            題中,n<=24,時間空間均有限制,我們可以先求出所有結果,然后保存到數組直接取來輸出。這是ACM題中很常見的情況。

             1 #include<stdio.h>
             2 int res[25]={0,0,0,4,6,0,0,12,40,0,0,171,410,
             3     0,0,1896,5160,0,0,32757,59984,0,0,431095,822229};
             4 int main()
             5 {
             6     int n;
             7     while(scanf("%d",&n),n)
             8     {
             9         printf("%d %d\n",n,res[n]);
            10     }
            11     return 0;
            12 }
            posted on 2010-10-11 09:13 孟起 閱讀(511) 評論(0)  編輯 收藏 引用 所屬分類: 遞推 遞歸
            久久精品国产亚洲av麻豆小说| 久久狠狠一本精品综合网| 亚洲а∨天堂久久精品| 亚洲精品综合久久| 一本一道久久综合狠狠老| 久久精品国产亚洲AV麻豆网站| 国产精品久久久天天影视| 99久久精品免费| 日本久久中文字幕| 久久人人爽爽爽人久久久| 久久se精品一区二区影院| 久久精品人人做人人妻人人玩| 亚洲Av无码国产情品久久| 精品国产乱码久久久久久浪潮| 97久久精品午夜一区二区| 亚洲精品无码成人片久久| 一本大道久久香蕉成人网| 欧美精品一区二区精品久久| 99久久精品免费看国产免费| 久久亚洲国产成人精品性色| 久久久久亚洲AV成人网人人软件| 国产成人精品综合久久久| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 久久精品女人天堂AV麻| 7777精品伊人久久久大香线蕉| 尹人香蕉久久99天天拍| 久久久久四虎国产精品| 久久精品国产久精国产果冻传媒| 久久精品国产免费观看| 久久久久人妻一区二区三区vr| 久久久不卡国产精品一区二区| 久久亚洲精品国产精品婷婷| 久久久久人妻一区精品性色av| 久久亚洲精品成人AV| 久久香综合精品久久伊人| 香蕉久久夜色精品国产2020| 日韩人妻无码精品久久免费一 | 国产免费久久久久久无码| 亚洲AV无码1区2区久久| 精品久久久久久无码国产| 亚洲精品乱码久久久久久蜜桃不卡 |