杭电oj1028

来源:互联网 发布:约束最优化方法 编辑:程序博客网 时间:2024/06/10 11:07
#include<iostream>
using namespace std;
int a[121][121];——//储存数组
long long q(int n,int m)
{
    if((n<1)||(m<1)) return 0;
    if((n==1)||(m==1)) return 1;
    if(n<m) return q(n,n);
    if(n==m) return q(n,m-1)+1;
    return q(n,m-1)+q(n-m,m);
}
int main()
{
    for(int i=1;i<=120;i++){
        for(int j=1;j<=120;j++){//由递归式转存到数组中,减少计算量
            if((i==1)||(j==1)) a[i][j]=1;
            else if(i<j) a[i][j]=a[i][i];
            else if(i==j) a[i][j]=a[i][j-1]+1;
            else a[i][j]=a[i][j-1]+a[i-j][j];
        }
    }
    int n;
    while(cin>>n){
        cout<<a[n][n]<<endl;
    }
    return 0;
}
原创粉丝点击