HDU 1085 Holding Bin-Laden Captive --生成函数第一题

时间:2023-03-09 01:36:39
HDU 1085 Holding Bin-Laden Captive --生成函数第一题

生成函数题。

题意:有币值1,2,5的硬币若干,问你最小的不能组成的币值为多少。

解法:写出生成函数:

HDU 1085 Holding Bin-Laden Captive --生成函数第一题

然后求每项的系数即可。

因为三种硬币最多1000枚,1*1000+2*1000+5*1000=8000,那么多项式乘积的最高次数为8000
用c保存累计相乘各项的系数,tc保存c和当前项相乘的系数

代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
using namespace std;
#define N 8007 int c[N],tc[N]; int main()
{
int num[],cnt[] = {,,};
int i,j,k;
while(scanf("%d%d%d",&num[],&num[],&num[])!=EOF)
{
if(num[] == && num[] == && num[] == )
break;
int maxi = num[] + *num[] + *num[]; for(i=;i<;i++)
c[i] = ,tc[i] = ; for(i=;i<=cnt[]*num[];i+=cnt[]) //第一个多项式的系数
c[i] = ; for(i=;i<;i++) //第几个多项式
{
for(j=;j<=maxi;j++) //累计的x^j的系数
{
for(k=;k+j<=maxi && k<=cnt[i]*num[i];k+=cnt[i]) //当前x^k的系数
tc[k+j] += c[j];
}
for(j=;j<=maxi;j++) //将结果保存到累计结果数组c中,重置tc
{
c[j] = tc[j];
tc[j] = ;
}
}
for(i=;i<=maxi;i++)
if(c[i] == )
break;
cout<<i<<endl;
}
return ;
}