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; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人