• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
            這是一道動態規劃的題目,狀態用d[i][j][k][l],表示取到第 i 個成品后手中還有 j Ak Bl C

             

            d[i+j][A][k+B][l+C]=min( d[i+j][A][k+B][l+C]d[i][j][k][l]+1 )

            這是很容易想到的。

             

            以下是我的程序:

            #include<stdio.h>
            #define maxint 30000
            #define min(a,b) (a<b?a:b)
            int n,d[101][11][11][11];
            char a[101]={0};
            void count(int begin,int end,int *A,int *B,int *C)
            {//------begin -> end
                int i;
                (
            *A)=(*B)=(*C)=0;
                
            for(i=begin;i<=end;i++)
                
            {
                        
            if(a[i]=='A') (*A)++;
                   
            else if(a[i]=='B') (*B)++;
                   
            else if(a[i]=='C') (*C)++;
                }

            }

            int main()
            {
                
            int i,j,k,l,A,B,C,m,ans;
                scanf(
            "%d\n",&n);
                
            for(i=1;i<=n;i++)
                  scanf(
            "\n%c",&a[i]);
                
            //------Read In
                for(i=1;i<=n;i++)
                 
            for(j=0;j<=10;j++)
                  
            for(k=0;k<=10;k++)
                   
            for(l=0;l<=10;l++)
                    d[i][j][k][l]
            =-1;
                count(
            1,(n>=10?10:n),&A,&B,&C);
                d[(n
            >=10?10:n)][A][B][C]=0;
                
            for(i=10;i<=n-1;i++)
                
            for(j=0;j<=10;j++)
                
            for(k=0;k<=10;k++)
                
            for(l=0;l<=10;l++)
                   
            if(d[i][j][k][l]!=-1)
                   
            {
                      
            if(j!=0)
                      
            {
                         m
            =i+j;
                        
            if(m>n) m=n;
                         count(i
            +1,m,&A,&B,&C);
                         
            if(d[m][A][k+B][l+C]==-1) d[m][A][k+B][l+C]=maxint;
                         d[m][A][k
            +B][l+C]=min(d[m][A][k+B][l+C],d[i][j][k][l]+1);
                      }

                      
            if(k!=0)
                      
            {
                         m
            =i+k;
                         
            if(m>n) m=n;
                         count(i
            +1,m,&A,&B,&C);
                         
            if(d[m][j+A][B][l+C]==-1) d[m][j+A][B][l+C]=maxint;
                         d[m][j
            +A][B][l+C]=min(d[m][j+A][B][l+C],d[i][j][k][l]+1);
                      }

                      
            if(l!=0)
                      
            {
                         m
            =i+l;
                         
            if(m>n) m=n;
                         count(i
            +1,m,&A,&B,&C);
                         
            if(d[m][j+A][k+B][C]==-1) d[m][j+A][k+B][C]=maxint;
                         d[m][j
            +A][k+B][C]=min(d[m][j+A][k+B][C],d[i][j][k][l]+1);
                      }

                   }

                ans
            =maxint;
                
            for(i=0;i<=10;i++)
                 
            for(j=0;j<=10;j++)
                  
            for(k=0;k<=10;k++)
                   
            if(d[n][i][j][k]!=-1)
                   
            {
                      
            if(i>0) d[n][i][j][k]++;
                      
            if(j>0) d[n][i][j][k]++;
                      
            if(k>0) d[n][i][j][k]++;
                      ans
            =min(ans,d[n][i][j][k]);
                   }

                printf(
            "%d\n",ans);//------Print
            return 0;
            }

            posted on 2010-01-06 18:48 lee1r 閱讀(369) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:動態規劃
            精品久久久久久无码中文野结衣| 国产成人久久777777| 久久人人爽人爽人人爽av| 久久久av波多野一区二区| 亚洲va久久久噜噜噜久久狠狠| 国产99久久久国产精品小说| 亚洲国产天堂久久综合| 狠狠色丁香久久婷婷综合蜜芽五月 | 色婷婷综合久久久久中文字幕| 久久99国产精品成人欧美| 狠狠精品干练久久久无码中文字幕| 国产精品久久久福利| 久久精品国产精品国产精品污 | 粉嫩小泬无遮挡久久久久久| 国产精品久久一区二区三区 | 久久综合久久综合亚洲| 狠狠综合久久AV一区二区三区| 亚洲午夜久久久影院伊人| 97久久久久人妻精品专区| a级毛片无码兔费真人久久| 亚洲国产成人久久精品99 | 四虎国产精品成人免费久久| 中文字幕无码av激情不卡久久| 77777亚洲午夜久久多喷| 久久99精品久久久久久动态图 | AV无码久久久久不卡网站下载 | 久久丫精品国产亚洲av不卡| 国产午夜精品理论片久久影视| 国产精品成人99久久久久91gav| 亚洲欧美另类日本久久国产真实乱对白 | 97超级碰碰碰久久久久| 狠狠精品久久久无码中文字幕 | 国内精品久久久久久久影视麻豆 | 99精品久久精品一区二区| 色综合久久久久久久久五月| 亚洲午夜久久久久久噜噜噜| 伊人久久大香线蕉综合网站| 国产欧美久久久精品影院| 国产亚洲美女精品久久久久狼| 久久影院久久香蕉国产线看观看| 国产午夜免费高清久久影院|