• <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>
            posts - 33,  comments - 33,  trackbacks - 0

            整數(shù)劃分問題是把一個(gè)正整數(shù) N 拆分成一組數(shù),并且使這組數(shù)相加等于 N 的問題.
            比如:
            6
            5 + 1
            4 + 2, 4 + 1 + 1
            3 + 3, 3 + 2 + 1, 3 + 1 + 1 + 1
            2 + 2 + 2, 2 + 2 + 1 + 1, 2 + 1 + 1 + 1 + 1
            1 + 1 + 1 + 1 + 1 + 1

            這里,5+1和1+5是同一種分法。
            這里探討整數(shù)劃分的可行解的數(shù)目。
            問題求解:
            首先假設(shè)正整數(shù)n拆分成k個(gè)數(shù)(不允許有0),用f(n,k)表示正整數(shù)n拆分成k個(gè)數(shù)的可行拆分種類的數(shù)目。
            那么
            f(n,n)表示n拆分成n個(gè)數(shù)(即只有n個(gè)1),顯然f(n,n) = 1
            然后,可以按照這k份中是否有一份的數(shù)為1分成兩類:
            1)   這k份中沒有1份含1的:那么可以在n中拿出k個(gè)"1"出來(lái),分到k份中,再將剩下n-k分到k份中,于是這時(shí)有
            f(n,k) = f(n-k,k)
            2)  這k份中至少有一份含有1:首先在n中拿1個(gè)"1"出來(lái),再將剩下n-1分到k-1份中,于是這時(shí)有:f(n,k) = f(n-1,k-1)

            綜合起來(lái)就是:
            f(n,n) = 1
            f(n,k) = f(n-k,k) + f(n-1,k-1)
            這兩個(gè)遞歸式可以使用動(dòng)態(tài)規(guī)劃求解。

            題目鏈接:
            http://poj.org/problem?id=1283
            題解:直接按照整數(shù)劃分來(lái)解
            代碼:
            import java.util.Scanner;
            import java.util.Arrays;;

            public class Main 
            {
                
            private static long [][]dp = new long[205][205];
                
                
            private static long Test(int _n,int _k)
                
            {
                    
            if(_n < _k)
                        
            return 0;
                    
            for(int i = 0; i <= _n; ++i)
                        Arrays.fill(dp[i],
            0);
                    
                    
            for(int i = 1; i <= _n; ++i)
                    
            {
                        dp[i][i] 
            = 1;
                    }

                    
                    
            for(int i = 2; i <= _n; ++i)
                    
            {
                        
            for(int j = 1; j <= _k; ++j)
                        
            {
                            dp[i][j] 
            = dp[i-1][j-1];
                            
            if(i - j > 0)
                                dp[i][j] 
            += dp[i-j][j];
                        }

                    }

                    
                    
            return dp[_n][_k];
                }

                
                
            public static void main(String[] args) 
                
            {
                    
            int n,k;
                    Scanner in 
            = new Scanner(System.in);
                    n 
            = in.nextInt();
                    k 
            = in.nextInt();
                    
            while(!(n == 0 &&  k == 0))
                    
            {
                        System.out.println(Test(n,k));
                        n 
            = in.nextInt();
                        k 
            = in.nextInt();
                    }


                }


            }


             

            代碼:
            import java.util.Scanner;
            import java.util.Arrays;

            public class Main 
            {
                
            private static long [][]dp = new long[32][32];
                
                
            private static long Test(int _n,int _k)
                
            {
                    
            if(_n < _k)
                        
            return 0;
                    
            for(int i = 0; i <= _n; ++i)
                        Arrays.fill(dp[i],
            0);
                    
                    
            for(int i = 1; i <= _n; ++i)
                    
            {
                        dp[i][i] 
            = 1;
                    }

                    
                    
            for(int i = 2; i <= _n; ++i)
                    
            {
                        
            for(int j = 1; j <= _k; ++j)
                        
            {
                            dp[i][j] 
            = dp[i-1][j-1];
                            
            if(i - j > 0)
                                dp[i][j] 
            += dp[i-j][j];
                        }

                    }

                    
                    
            return dp[_n][_k];
                }

                
                
            public static void main(String[] args) 
                
            {
                    Scanner in 
            = new Scanner(System.in);
                    
            int testcase = in.nextInt();
                    
            int m,n;
                    
            for(int i =0; i < testcase; ++i)
                    
            {
                        m 
            = in.nextInt();
                        n 
            = in.nextInt();
                        System.out.println(Test(m
            +n,n));
                    }

                }

            }



            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国产精品成人精品久久久| 国产成人无码久久久精品一| 精品国产婷婷久久久| 香蕉久久夜色精品国产尤物| 久久人人妻人人爽人人爽| 国产精品亚洲综合专区片高清久久久| 国产精品激情综合久久| 久久无码AV一区二区三区| 久久人妻AV中文字幕| 久久久噜噜噜www成人网| 91精品观看91久久久久久| 久久精品国产第一区二区三区| 精品久久久久久中文字幕| 精品乱码久久久久久久| 亚洲一区中文字幕久久| 综合久久国产九一剧情麻豆| 久久久久久免费视频| 精品久久久久久亚洲| 亚洲精品国产字幕久久不卡| 欧美精品久久久久久久自慰| 一本久久a久久精品亚洲| 99久久婷婷国产综合精品草原 | 亚洲精品高清一二区久久| 久久99国产精品成人欧美| 久久亚洲日韩精品一区二区三区| 三级片免费观看久久| 伊人久久大香线蕉精品不卡| 麻豆精品久久久一区二区| 欧美精品一本久久男人的天堂| 狠狠综合久久AV一区二区三区| 亚洲Av无码国产情品久久| 久久免费大片| 亚洲国产欧美国产综合久久| 精品国产乱码久久久久软件| 久久久久亚洲国产| 久久精品免费一区二区| 国产精品久久久久久五月尺| 漂亮人妻被中出中文字幕久久 | 久久亚洲AV永久无码精品| 久久精品国产国产精品四凭 | 亚洲愉拍99热成人精品热久久|