• <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
                    每個符號三角形都是由它的第一行“+,-”號分布決定的,據(jù)此可演算出所有分布的三角形,對其進行統(tǒng)計即可。

                    同時將一個n行三角形T+,-號個數(shù)分別記為pos_num(n),neg_num(n),其第一行中的+,-號個數(shù)記為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的結(jié)果,迭代求出n=k的分布情形,然后對n=k的所有分布統(tǒng)計。

            #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//記錄+,-的個數(shù)
                            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,時間空間均有限制,我們可以先求出所有結(jié)果,然后保存到數(shù)組直接取來輸出。這是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)  編輯 收藏 引用 所屬分類: 遞推 遞歸
            久久久无码精品亚洲日韩按摩| 欧美久久天天综合香蕉伊| 久久九九兔免费精品6| 日韩精品久久久久久免费| 九九久久自然熟的香蕉图片| 久久97精品久久久久久久不卡| 99久久国产免费福利| 成人综合久久精品色婷婷| 精品永久久福利一区二区| 久久久99精品成人片中文字幕 | 久久久精品人妻无码专区不卡 | 伊人久久精品无码二区麻豆| 国产情侣久久久久aⅴ免费| 精品无码久久久久久久动漫| 久久国产欧美日韩精品| 久久精品国产99久久久香蕉| 日韩人妻无码精品久久免费一 | 久久精品国产69国产精品亚洲| 久久人人爽人人爽AV片| 精品久久久久久亚洲精品| 免费精品国产日韩热久久| 精品久久久久久亚洲| 人妻精品久久无码专区精东影业 | 亚洲国产日韩欧美综合久久| 国产V亚洲V天堂无码久久久| 亚洲国产成人久久精品99 | 久久久无码精品午夜| 久久99国产精品二区不卡| 777午夜精品久久av蜜臀| 国产一区二区三精品久久久无广告 | 久久综合狠狠综合久久| 一本大道久久a久久精品综合| 精品久久久无码21p发布| 三级韩国一区久久二区综合 | 国产精品久久久久免费a∨| 九九久久精品无码专区| 久久综合综合久久97色| 午夜精品久久久久久毛片| 99久久这里只精品国产免费 | 色综合久久久久无码专区| 一本色道久久88—综合亚洲精品|