用背包问题解一个旅行者准备随身携带一个背包,可以放入背包的物品有n种,物品j的重量跟价值分别为w和v,j=1,2,...,n,如果背包的最大重量限制是b,怎样选择放入背包的物品能使得背包的价值最大c++代码
时间: 2024-11-25 19:22:27 浏览: 0
旅行者的背包问题,也被称为0-1背包问题,是一个经典的动态规划问题。在C++中解决这个问题通常涉及创建一个二维数组,其中每个元素dp[i][j]表示在容量i的情况下,前j个物品能够获得的最大价值。
以下是基本的C++代码实现:
```cpp
#include <iostream>
#include <vector>
int knapSack(int W, std::vector<int>& wt, std::vector<int>& val, int n) {
std::vector<std::vector<int>> dp(n + 1, std::vector<int>(W + 1, 0));
for (int i = 1; i <= n; ++i) {
for (int w = 1; w <= W; ++w) {
if (wt[i - 1] <= w) {
// 如果当前物品小于等于剩余容量,可以选择它,取最大值
dp[i][w] = std::max(dp[i - 1][w], dp[i - 1][w - wt[i - 1]] + val[i - 1]);
} else {
// 当前物品太大,无法装入,直接沿用之前的结果
dp[i][w] = dp[i - 1][w];
}
}
}
return dp[n][W];
}
int main() {
int b = 50; // 背包容量
std::vector<int> wt = {10, 20, 30}; // 物品重量
std::vector<int> val = {60, 100, 120}; // 物品价值
int n = wt.size(); // 物品种类数
int max_value = knapSack(b, wt, val, n);
std::cout << "背包内物品最大总价值为: " << max_value << std::endl;
return 0;
}
```
这个程序首先初始化一个动态规划表,然后通过两层循环遍历所有可能的组合,根据物品的重量和剩余背包容量做出决策。最后返回背包所能达到的最大价值。
阅读全文