可以想到最优情况一定是相互互质,把素数从小到大排,动态规划
dp[x][y]记录的是加起来的和小于等于k并且最大的质素小于等于prime[y]的方法数,转移方程就自然而然出来了
特殊情况预处理掉,比如说和为0的方法数为1,不取在某种意义上也是一种方法 —— dp[0][x]=1
和为1的预处理掉 —— dp[1][x]=1
最大素数大小不超过2的也预处理掉 —— dp[x][0]=log2(x)
复杂度O(n*(n以内质素的个数)*log(n))
#include<iostream>
#include<vector>
#include<algorithm>
#include<cstdio>
#include<queue>
#include<stack>
#include<string>
#include<map>
#include<set>
#include<cmath>
#include<cassert>
#include<cstring>
#include<iomanip>
using namespace std;
#ifdef _WIN32
#define i64 __int64
#define out64 "%I64d\n"
#define in64 "%I64d"
#else
#define i64 long long
#define out64 "%lld\n"
#define in64 "%lld"
#endif
/************ for topcoder by zz1215 *******************/
#define FOR(i,a,b) for( int i = (a) ; i <= (b) ; i ++)
#define FFF(i,a) for( int i = 0 ; i < (a) ; i ++)
#define FFD(i,a,b) for( int i = (a) ; i >= (b) ; i --)
#define S64(a) scanf(in64,&a)
#define SS(a) scanf("%d",&a)
#define LL(a) ((a)<<1)
#define RR(a) (((a)<<1)+1)
#define pb push_back
#define CL(Q) while(!Q.empty())Q.pop()
#define MM(name,what) memset(name,what,sizeof(name))
#define MAX(a,b) ((a)>(b)?(a):(b))
#define MIN(a,b) ((a)<(b)?(a):(b))
#define read freopen("out.txt","r",stdin)
#define write freopen("zz.txt","w",stdout)
const int inf = 0x3f3f3f3f;
const i64 inf64 = 0x3f3f3f3f3f3f3f3fLL;
const double oo = 10e9;
const double eps = 10e-9;
const double pi = acos(-1.0);
const int maxn = 1001;
i64 dp[maxn][maxn];
vector<int>p;
bool isp(int x)
{
for(int i=0;p[i]*p[i]<=x;i++)
{
if(x%p[i]==0)
{
return false;
}
}
return true;
}
void initp()
{
p.clear();
p.pb(2);
for(int i=3;i<1000;i++)
{
if(isp(i))
{
p.pb(i);
}
}
return ;
}
void start()
{
MM(dp,0);
int now,temp;
for(int i=0;i<p.size();i++)
{
dp[1][i]=1;
dp[0][i]=1;
}
int next=2;
temp=1;
for(int i=2;i<maxn;i++)
{
if(i==next)
{
next*=2;
temp++;
}
dp[i][0]=temp;
}
for(int i=2;i<maxn;i++)
{
for(int j=1;j<p.size();j++)
{
dp[i][j]+=dp[i][j-1];
now=p[j];
while(now<=i)
{
dp[i][j]+=dp[i-now][j-1];
now*=p[j];
}
}
}
return ;
}
int n;
int main()
{
initp();
start();
while(cin>>n)
{
cout<<dp[n][p.size()-1]<<endl;
}
return 0;
}