标签:
1 6
11
下面转自博客:http://www.cnblogs.com/hoodlum1980/archive/2008/10/11/1308493.html
所谓整数划分,是指把一个正整数n写成如下形式:
n=m1+m2+...+mi; (其中mi为正整数,并且1 <= mi <= n),则:{m1,m2,...,mi}为n的一个划分。
如果{m1,m2,...,mi}中的最大值不超过m,即max(m1,m2,...,mi)≤m,则称它属于n的一个m划分。这里我们记n的m划分的个数为f(n,m);
例如:当n=4时,共有5个划分,{4},{3,1},{2,2},{2,1,1},{1,1,1,1};
注意4=1+3 和 4=3+1被认为是同一个划分。
该问题是求出n的所有划分个数,即f(n, n)。
通用的递推公式如下:
f(n, m) = 1; ( n = 1 or m = 1 )
f(n, n); ( n < m )
1+ f(n, m - 1); ( n = m )
f(n - m, m) + f(n, m - 1); ( n > m )
#include <cstdio> #include <iostream> using namespace std; int f(int i, int j) { if(i==1 || j==1) return 1; if(i<j) return f(i, i); if(i==j) return f(i, i-1) + 1; return f(i, j-1) + f(i-j, j); } int main () { int T, n; scanf("%d", &T); while(T--) { scanf("%d", &n); printf("%d\n", f(n, n)); } return 0; }
标签:
原文地址:http://www.cnblogs.com/AcIsFun/p/5346053.html