仔细观察,很容易发现规律。
以下是我的代码:
#include<stdio.h>
#define MAXN 1010
typedef unsigned long Long;
Long f(Long x,Long a)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
Long i,re=1;
for(i=1;i<=a;i++)
re*=x;
return re;
}
int main()
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
Long k,n,i,count,tot,tmp,a[MAXN]=
{0};
scanf("%lu%lu",&k,&n);
tot=0;
count=0;
while(tot<n)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
tot++;
tmp=tot;
a[tot]=f(k,count);
count++;
for(i=1;i<tmp;i++)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
tot++;
a[tot]=a[i]+a[tmp];
if(tot>=n) break;
}
}
printf("%lu\n",a[n]);
// getchar();getchar();
return 0;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
posted on 2010-01-06 20:33
lee1r 阅读(228)
评论(0) 编辑 收藏 引用 所属分类:
题目分类:递推/递归