lightoj1231【背包】
题意:
有n种货币,已知每种货币的价值和数量。
给出一个k,问最多能组成k的方法。这个数量很大,需要mod 1e8+7.
思路:
额。。。。这一题和上一篇的差不多,直接传送门:
(此题很棒)
这里的话就是类似啊:
dp[i][j]:前i种硬币组成j有多少种方法。
但是每次要模
code…
#include<bits/stdc++.h>
//#include<cstdio>
//#include<math.h>
//#include<string.h>
//#include<algorithm>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
const double eps=1e-5;
const double pi=acos(-1.0);
const int mod=1e8+7;
const LL INF=0x3f3f3f3f;
const int N=1e3+10;
int dp[N];
int a[55];
int b[55];
int main()
{
int t,i,k,j,n;
int c,g;
int cas=1;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&k);
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
for(i=1;i<=n;i++)
scanf("%d",&b[i]);
memset(dp,0,sizeof(dp));
dp[0]=1;
for(i=1;i<=n;i++)
for(j=k;j>=0;j--)
for(c=1;c<=b[i];c++)
if((j-c*a[i])>=0){
dp[j]+=dp[j-c*a[i]];
dp[j]%=mod;
}
printf("Case %d: %d\n",cas++,dp[k]);
}
}