给定一个整数n,要找出n能拆分成多少种不同的若干个数的和与乘积的形式。比如:
4=4 12=1*12
4=1+3 12=2*6
4=2+2 12=3*4
4=1+1+2 12=2*2*3
4=1+1+1+1
先看加法形式,可以构造一个母函数F(x)=(1+x+x^2+...+x^n)(1+x^2+x^4+...+x^n)...(1+x^n),将这个母函数展开后,求出每一个x^k前面的系数Ck,就是对应的整数K有多少种拆分的形式。
对于乘积的形式,设n=i*j,dp[n]为整数n拆分成乘积形式的个数,dp[n]=∑dp[i]=∑dp[j] (i∈{i : i*j=n},j∈{j : i*j=n}),这就是这个问题的状态转移方程,具有动态规划问题的最有子结构性质。