#include<iostream> using namespace std; const int N = 2005; int w[N], v[N]; int dp[N][10005]; int n, m, k; int find(int ww) { int ma = 0; for (int i = n; i >= 1; i--) { if(dp[i][ww] !=dp[i-1][ww]) { ma = max(ma, v[i]); ww -= w[i]; } } return ma; } int main() { cin >> n >> m >> k; for (int i = 1; i <= n; i++) { cin >> w[i] >> v[i]; } for (int i = 1; i <= n; i++) { for (int j = 1; j <= m; j++) { if (w[i] > j) dp[i][j] = dp[i-1][j]; else dp[i][j] = max(dp[i-1][j], v[i] + dp[i - 1][j - w[i]]); } } int res = 0; for (int i = 1; i <= m-k; i++) { res = max(res, find(i)+ dp[n][i]); } res = max(dp[n][m], res); cout << res<<endl; return 0; }
时间: 2024-04-28 14:22:05 浏览: 46
字节跳动2018校招大数据方向(第一批).pdf
这是一段背包问题的动态规划代码。输入n个物品的重量和价值,背包的容量为m,最多只能选k个物品,求能够装入背包的最大价值。
代码中使用了一个二维数组dp[i][j],表示前i个物品放入容量为j的背包中的最大价值。其中dp[i-1][j-w[i]]表示在不选第i个物品的情况下,剩余容量为j-w[i]的背包中的最大价值,v[i]表示选第i个物品的价值,因此状态转移方程为:
dp[i][j] = max(dp[i-1][j], v[i] + dp[i-1][j-w[i]])
在求解的过程中,还需要使用find函数来找到最大的价值,其思路为从后往前遍历dp数组,当dp[i][j]不等于dp[i-1][j]时,说明第i个物品被选中了,更新最大价值并减去选中物品的重量。
最终的答案为dp[n][m]和find(i)+ dp[n][i]中的最大值。
阅读全文