AcWing算法提高课 背包问题求方案数

背包问题可以用dp数组记录最大值。

可以新增另一个数组count,记录等于最大值的方案数,

这样,在算出最大值后,在求解一遍可以以最大值转移过来的方案数的和,即可得到最大值的方案数。

AcWing 11. 背包问题求方案数 

代码如下:

复制代码
#include<bits/stdc++.h>
using namespace std;

long long dp[1010][1010];
long long ccount[1010][1010];
long long MOD=1000000007;
int main()
{

    int n,V;
    cin>>n>>V;
    for(int i=0;i<=V;i++)
        ccount[0][i]=1;
    for(int i=1;i<=n;i++)
    {
        int v,val;
        cin>>v>>val;
        for(int j=0;j<=V;j++)
        {
            dp[i][j]=dp[i-1][j];
            if(j>=v) dp[i][j]=max(dp[i][j],dp[i-1][j-v]+val);
        }
        for(int j=0;j<=V;j++)
        {
            if(dp[i][j]==dp[i-1][j]) ccount[i][j]+=ccount[i-1][j];
            if(j>=v&&dp[i][j]==dp[i-1][j-v]+val) ccount[i][j]+=ccount[i-1][j-v];

            ccount[i][j]%=MOD;
        }
    }
    cout<<ccount[n][V]<<endl;
}
View Code
复制代码

 

posted @   80k  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示