• <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>

            M.J的blog

            algorithm,ACM-ICPC
            隨筆 - 39, 文章 - 11, 評論 - 20, 引用 - 0
            數據加載中……

            【DP】TOJ 2820 How many different ways

            給定從1 到 N的 N 個數,問有多少種不同方案劃分這些數。比如N = 3,則有5種方案:
            {{1},{2},{3}}
            {{1,2},{3}}
            {{1,3},{2}}
            {{2,3},{1}}
            {{1,2,3}}
            最后的結果只保留后四位,即mod10000;
            上網查了下,集合的劃分的個數叫做bell數,bell數可以遞歸求解:
            bell[0] = 1;
            bell [n + 1] = sigma(C(n,k))*(bell[k]); (0<=k<=n)

             
            然而這個題卻不可以這樣做,因為N得范圍是2000,這樣做必定超時,于是想到了DP,如果用dp[i][j]表示i個數
            劃分成j個集合,那么便有dp[i][j] = j * dp[i-1][j] + dp[i-1][j-1];( i > j )直觀理解就是,將i個數劃分成j個集合的個數,即為i-1個數劃分到j個集合的數,再將多的那個依次放到j個集合中,所以乘以j,或者是i-1個數放在j-1個集合中,第j個集合為空,則正好將多的這個數放到這個集合中,于是便有上邊的狀態轉移方程。
            Code:

             

            #include <cstdio>
            #include 
            <iostream>
            #include 
            <cmath>
            using namespace std;

            int map[2002][2002];
            void DP(){
                memset(map,
            0,sizeof(map));
                
            int i,j,k;
                
            for(i = 0;i <= 2000; i++){
                    map[i][i] 
            = 1;
                    map[i][
            1= 1;
                }

                
            for(i = 0;i <= 2000 ;i++)
                    
            for(j = 0; j < i; j++)
                        map[i][j] 
            = (j * map[i-1][j] + map[i-1][j-1])%10000;
            }

            int main()
            {
                
            int i,j,k,n;
                DP();
                
            while(scanf("%d",&n),n){
                    
            int ans = 0;
                    
            for(i = 0;i <= n; i++)
                        ans 
            = (ans + map[n][i])%10000;
                    
            string str = "0000";
                    str[
            3= ans%10+'0'; ans/=10;
                    str[
            2= ans%10+'0'; ans/=10;
                    str[
            1= ans%10+'0'; ans/=10;
                    str[
            0= ans%10+'0'; ans/=10;
                    cout
            <<str<<endl;
                }

            }

            posted on 2010-06-12 15:05 M.J 閱讀(315) 評論(0)  編輯 收藏 引用

            亚洲伊人久久成综合人影院| 色天使久久综合网天天| 国产精品禁18久久久夂久| 久久久久亚洲AV无码永不| 青青草国产成人久久91网| 少妇被又大又粗又爽毛片久久黑人| 久久99久久99精品免视看动漫| 久久99精品久久只有精品| 欧洲国产伦久久久久久久| 久久人妻无码中文字幕| 国产午夜福利精品久久| 亚洲国产精品无码久久一线| 99国内精品久久久久久久| 久久久久久国产精品无码超碰| 久久国产一区二区| 中文字幕人妻色偷偷久久| 精品国产乱码久久久久久浪潮| 777午夜精品久久av蜜臀| 久久精品亚洲福利| 久久久九九有精品国产| 色天使久久综合网天天| 91超碰碰碰碰久久久久久综合| 亚洲国产一成人久久精品| 久久久久香蕉视频| 99久久人人爽亚洲精品美女| 久久久亚洲欧洲日产国码aⅴ| 国产激情久久久久久熟女老人| 色偷偷88欧美精品久久久| 久久精品国产亚洲5555| 日本道色综合久久影院| 国产精品禁18久久久夂久| 77777亚洲午夜久久多喷| 日本欧美久久久久免费播放网| 久久只这里是精品66| 亚洲v国产v天堂a无码久久| 午夜精品久久久久久| 日本精品久久久久影院日本 | 久久午夜福利无码1000合集| 亚洲另类欧美综合久久图片区| 久久久99精品成人片中文字幕 | 国产精品久久久久无码av|