刚开始时用递归做的,果断超时!后来就知道用数组吧全部算出来。
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
const int N=121;
int dp[N][N];
int main()
{
int n,m;
for(int i=1;i<=120;i++)
{
dp[1][i]=1;
dp[i][1]=1;
}
for(int i=1;i<=120;i++)
for(int j=1;j<=120;j++)
{
if(i>j)
dp[i][j]=dp[i-j][j]+dp[i][j-1];
if(i==j)
dp[i][j]=dp[i][j-1]+1;
if(i<j)
dp[i][j]=dp[i][i];
}
while(scanf("%d",&n)!=EOF)
{
cout<<dp[n][n]<<endl;
}
system("pause");
return 0;
}