完全背包问题动态规划c++代码
时间: 2023-09-05 19:10:00 浏览: 101
以下是完全背包问题的动态规划实现的C代码:
```c
#include<stdio.h>
#define MAXN 1000 //物品的最大数量
#define MAXV 1000 //背包的最大容量
int dp[MAXV+1]; //dp[i]表示容量为i的背包所能装下物品的最大价值
int v[MAXN]; //v[i]表示第i个物品的体积
int w[MAXN]; //w[i]表示第i个物品的价值
int n; //物品的数量
int m; //背包的容量
int main(){
scanf("%d %d",&n,&m);
for(int i=1;i<=n;++i){
scanf("%d %d",&v[i],&w[i]);
}
for(int i=1;i<=m;++i){
for(int j=1;j<=n;++j){
if(v[j]<=i){
dp[i]=max(dp[i],dp[i-v[j]]+w[j]);
}
}
}
printf("%d",dp[m]);
return 0;
}
```
注:本代码中使用了max函数,需要先进行定义,可以使用以下代码实现:
```c
int max(int a,int b){
return a>b?a:b;
}
```
相关问题
完全背包问题动态规划c++代码,并输出选取物品
以下是完全背包问题的动态规划代码,其中包括了输出选取物品的部分:
```
#include <stdio.h>
#define MAX_N 100
#define MAX_W 1000
int n, W;
int w[MAX_N], v[MAX_N];
int dp[MAX_N+1][MAX_W+1];
void solve() {
for (int i = 0; i < n; i++) {
for (int j = 0; j <= W; j++) {
for (int k = 0; k * w[i] <= j; k++) {
dp[i+1][j] = max(dp[i+1][j], dp[i][j-k*w[i]] + k*v[i]);
}
}
}
printf("最大价值为:%d\n", dp[n][W]);
// 输出选取的物品
int i = n, j = W;
int x[MAX_N] = {0};
while (i > 0 && j > 0) {
if (dp[i][j] != dp[i-1][j]) {
x[i-1]++;
j -= w[i-1];
} else {
i--;
}
}
printf("选取的物品为:\n");
for (int i = 0; i < n; i++) {
if (x[i] > 0) {
printf("物品%d选取了%d个\n", i+1, x[i]);
}
}
}
int main() {
scanf("%d%d", &n, &W);
for (int i = 0; i < n; i++) {
scanf("%d%d", &w[i], &v[i]);
}
solve();
return 0;
}
```
输入格式为:
```
n W
w[0] v[0]
w[1] v[1]
...
w[n-1] v[n-1]
```
其中,n表示物品的数量,W表示背包的容量,w[i]和v[i]分别表示第i件物品的重量和价值。
输出格式为:
```
最大价值为:xxx
选取的物品为:
物品x选取了y个
物品x选取了y个
...
```
其中,最大价值表示背包能够装下的最大价值,选取的物品部分表示每个物品选取的个数。
完全背包问题c++代码
以下是完全背包问题的 C++ 代码,使用动态规划实现:
```cpp
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int knapsack(int W, vector<int>& wt, vector<int>& val, int n) {
vector<int> dp(W + 1, 0);
for (int i = 0; i <= W; i++) {
for (int j = 0; j < n; j++) {
if (wt[j] <= i) {
dp[i] = max(dp[i], dp[i - wt[j]] + val[j]);
}
}
}
return dp[W];
}
int main() {
int W = 50;
vector<int> wt = {10, 20, 30};
vector<int> val = {60, 100, 120};
int n = wt.size();
cout << knapsack(W, wt, val, n) << endl;
return 0;
}
```
其中,`W` 表示背包的容量,`wt` 和 `val` 分别表示物品的重量和价值,`n` 表示物品的数量。`dp` 数组表示当前容量下能够获得的最大价值。通过两层循环,不断更新 `dp` 数组,最终返回 `dp[W]` 表示容量为 `W` 时能够获得的最大价值。
阅读全文