zoukankan      html  css  js  c++  java
  • 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
    ",cas++,dp[k]);
        }
    }
  • 相关阅读:
    NET CORE 数据库迁移
    VUE3.0 解析svg文件
    关于ElementUI的样式不生效
    git命令
    vue 2.x的跨域问题
    Putty 重新启动 linux sqlserver服务
    aspnetcore之session
    Syncfusion 在 core 的架构
    TortoiseSVN创建/合并分支
    正则表达式知识点整理
  • 原文地址:https://www.cnblogs.com/keyboarder-zsq/p/5934406.html
Copyright © 2011-2022 走看看