33,007
社区成员
发帖
与我相关
我的任务
分享
#include <iostream>
#define MAX 100
using namespace std;
int a[]={1,2,5,10};
int M[MAX]={0};
int foo(int size)
{
if(size==1){return 1;}
if(size<=0){return 0;}
int sum=0;
for(int i=0;i<4;i++)
{
if(size-a[i]>0){
if(M[size-a[i]]==0)
sum+=foo(size-a[i]);
else
sum+=M[size-a[i]];
}
else if(size==a[i]){sum++;}
}
M[size]=sum;
return sum;
}
int main()
{
int size;
cin>>size;
cout<<foo(size)<<endl;
}
#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;
int a[10];
int M[10]={0};
int foo()
{
M[0]=1;
int max=M[0];
for(int i=1;i<10;i++)
{
M[i]=1;
for(int j=0;j<i;j++)
{
if(a[i]>a[j])
{
if(M[i]<M[j]+1)M[i]=M[j]+1;
}
}
if(M[i]>max)max=M[i];
}
return max;
}
int main()
{
srand(time(NULL));
for(int i=0;i<10;i++)
{
a[i]=rand()%20+1;
cout<<a[i]<<",";
}
cout<<"\n"<<foo()<<endl;
}