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]);
    }
}
posted @ 2016-07-24 22:06  see_you_later  阅读(94)  评论(0编辑  收藏  举报