#include <stdio.h>
#include <stdlib.h>
#define iSize 5
int max(int m, int n)
{
return m > n ? m : n;
}
int min(int m, int n)
{
return m > n ? n : m;
}
void knapsack(int v[], int w[], int c, int *m[], int len)
{
int n = len - 1;
int jMax = min(w[n] - 1, c);
int i, j;
for (j = 0; j <= jMax; j++)
m[n][j] = 0;
for (j = w[n]; j <= c; j++)
m[n][j] = v[n];
for (i = n - 1; i > 1; i--)
{
jMax = min(w[i] - 1, c);
for (int j = 0; j <= jMax; j++)
m[i][j] = m[i+1][j];
for (j = w[i]; j <= c; j++)
m[i][j] = max(m[i + 1][j], m[i + 1][j - w[i]] + v[i]);
}
m[1][c] = m[2][c];
if (c >= w[1])
m[1][c] = max(m[1][c], m[2][c - w[1]] + v[1]);
}
int main()
{
int v[iSize] = {6, 3, 5, 4, 6};
int w[iSize] = {2, 2, 6, 5, 4};
int c = 10;
int **m = new int*[5];
for (int i = 0; i < iSize; i++)
m[i] = new int[c];
knapsack(v, w, c, m, iSize);
printf("%d\n", m[1][c]);
delete m;
system("pause");
return 0;
}
DP.rar_dp算法
版权申诉
92 浏览量
2022-09-24
15:54:28
上传
评论
收藏 101KB RAR 举报
JonSco
- 粉丝: 67
- 资源: 1万+
最新资源
- 论文(最终)_20240430235101.pdf
- 基于python编写的Keras深度学习框架开发,利用卷积神经网络CNN,快速识别图片并进行分类
- 最全空间计量实证方法(空间杜宾模型和检验以及结果解释文档).txt
- 5uonly.apk
- 蓝桥杯Python组的历年真题
- 2023-04-06-项目笔记 - 第一百十九阶段 - 4.4.2.117全局变量的作用域-117 -2024.04.30
- 2023-04-06-项目笔记 - 第一百十九阶段 - 4.4.2.117全局变量的作用域-117 -2024.04.30
- 前端开发技术实验报告:内含4四实验&实验报告
- Highlight Plus v20.0.1
- 林周瑜-论文.docx
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈