#include

#define MAX_NUM 5

#define MAX_WEIGHT 10

using namespace std;

//动态规划求解

int zero_one_pack(int total_weight, int w[], int v[], int flag[], int n) {

int c[MAX_NUM+1][MAX_WEIGHT+1] = {0}; //c[i][j]表示前i个物体放入容量为j的背包获得的最大价值

// c[i][j] = max{c[i-1][j], c[i-1][j-w[i]]+v[i]}

//第i件物品要么放,要么不放

//如果第i件物品不放的话,就相当于求前i-1件物体放入容量为j的背包获得的最大价值

//如果第i件物品放进去的话,就相当于求前i-1件物体放入容量为j-w[i]的背包获得的最大价值

for (int i = 1; i <= n; i++) {

for (int j = 1; j <= total_weight; j++) {

if (w[i] > j) {

// 说明第i件物品大于背包的重量,放不进去

c[i][j] = c[i-1][j];

} else {

//说明第i件物品的重量小于背包的重量,所以可以选择第i件物品放还是不放

if (c[i-1][j] > v[i]+c[i-1][j-w[i]]) {

c[i][j] = c[i-1][j];

}

else {

c[i][j] = v[i] + c[i-1][j-w[i]];

}

}

}

}

//下面求解哪个物品应该放进背包

int i = n, j = total_weight;

while (c[i][j] != 0) {

if (c[i-1][j-w[i]]+v[i] == c[i][j]) {

// 如果第i个物体在背包,那么显然去掉这个物品之后,前面i-1个物体在重量为j-w[i]的背包下价值是最大的

flag[i] = 1;

j -= w[i];

//--i; 移到外面去

}--i;

}

return c[n][total_weight];

}

//回溯法求解

int main() {

int total_weight = 10;

int w[4] = {0, 3, 4, 5};

int v[4] = {0, 4, 5, 6};

int flag[4]; //flag[i][j]表示在容量为j的时候是否将第i件物品放入背包

int total_value = zero_one_pack(total_weight, w, v, flag, 3);

cout << "需要放入的物品如下" << endl;

for (int i = 1; i <= 3; i++) {

if (flag[i] == 1)

cout << i << "重量为" << w[i] << ", 价值为" << v[i] << endl;

}

cout << "总的价值为: " << total_value << endl;

return 0;

}

开心洋葱 , 版权所有丨如未注明 , 均为原创丨未经授权请勿修改 , 转载请注明c++实现0-1背包问题完整源码(动态规划实现)!

c语言动态规划0-1背包,c++实现0-1背包问题完整源码(动态规划实现)相关推荐

  1. C语言二叉树的lowest common ancestor最低公共祖先(附完整源码)

    C语言二叉树的lowest common ancestor最低公共祖先 C语言二叉树的lowest common ancestor最低公共祖先完整源码(定义,实现,main函数测试) C语言二叉树的l ...

  2. C语言二叉搜索树返回key的树级(附完整源码)

    C语言二叉搜索树返回key的树级 C语言二叉搜索树返回key的树级完整源码(定义,实现,main函数测试) C语言二叉搜索树返回key的树级完整源码(定义,实现,main函数测试) #include ...

  3. C语言最简单的sleep sort睡眠排序实现(附完整源码)

    C语言最简单的sleep sort睡眠排序实现 C语言最简单的sleep sort睡眠排序实现完整源码(定义,实现,main函数测试) C语言最简单的sleep sort睡眠排序实现完整源码(定义,实 ...

  4. C语言求在算术级数中找到缺少的数字(附完整源码)

    C语言求在算术级数中找到缺少的数字 在算术级数中找到缺少的数字 C语言求在算术级数中找到缺少的数字完整源码(定义,实现,main函数测试) 在算术级数中找到缺少的数字 Examples: Input: ...

  5. C语言二分法在一个有序数组查找数的算法(附完整源码)

    C语言二分法在一个有序数组查找数 二分法在一个有序数组查找数 C语言分治法来计算pow(x,y)完整源码(定义,实现,main函数测试) 二分法在一个有序数组查找数 给定一个排序数组和一个数字. 用户 ...

  6. C语言通过链表指针删除链表节点的算法(附完整源码)

    C语言通过链表指针删除链表节点的算法 C语言通过链表指针删除链表节点的算法完整源码(定义,实现,main函数测试) C语言通过链表指针删除链表节点的算法完整源码(定义,实现,main函数测试) #in ...

  7. C语言Huffman Encode霍夫曼编码的算法(附完整源码)

    C语言Huffman Encode霍夫曼编码的算法 C语言Huffman Encode霍夫曼编码的算法完整源码(定义,实现,main函数测试) C语言Huffman Encode霍夫曼编码的算法完整源 ...

  8. C语言检查列表是否是回文的算法(附完整源码)

    C语言检查列表是否是回文的算法 C语言检查列表是否是回文的算法完整源码(定义,实现,main函数测试) C语言检查列表是否是回文的算法完整源码(定义,实现,main函数测试) #include < ...

  9. C语言删除单链列表中间的节点的算法(附完整源码)

    C语言删除单链列表中间的节点的算法 C语言删除单链列表中间的节点的算法完整源码(定义,实现,main函数测试) C语言删除单链列表中间的节点的算法完整源码(定义,实现,main函数测试) #inclu ...

最新文章

  1. shell中竖线的作用_如何在 Linux 中安装、配置和使用 Fish Shell?
  2. RDKit | 基于随机森林(RF)的机器学习模型预测hERG阻断剂活性
  3. 2021年春季学期-信号与系统-第六次作业参考答案-第五小题
  4. uva 10047 the monocyle (四维bfs)
  5. Angular中使用双向数据绑定操作表单的input、checkboc、radio、select、textarea实现简单的人员登记系统实例
  6. vue学习笔记-01-前端的发展历史(从后端到前端,再到前后端分离,再到全栈)
  7. 怎么更改Windows11鼠标指针大小和样式
  8. Mybatis传递多个参数
  9. .net网页的生命周期列表
  10. Visio图片导出不清晰
  11. 五矿系30亿项目未经环评私行上马遭环保部叫停
  12. Vscode——内置浏览器
  13. http请求中简单的签名验证
  14. FZUOJ 2214 Knapsack problem 背包
  15. 2020年保育员(中级)多少分及格及保育员(中级)模拟考试系统
  16. java几种对象的区别(PO,POJO,VO,BO,DAO)
  17. 头牌知产介绍空气炸锅商标转让类别
  18. Android---App Widget(官方文档翻译)
  19. 2022年(23届)电子信息/通信工程保研|四非上岸浙大的保研之旅(浙大、中科大、哈工大、东南、南开、西电、成电等)
  20. 嵌入式系统232串口测试笔记

热门文章

  1. GeForce 3080更新470驱动出错的解决方案
  2. java集合数据复制到另外一个集合
  3. u盘中删除的文件怎样才能恢复呢?
  4. 计算机科学梗,只有本专业的人才明白的梗,你看懂了几个?
  5. SuperMap GIS三维插件使用QA
  6. 5000学软件测试买什么电脑好,大学学的软件工程,买什么电脑合适,预算不超过7000?...
  7. [kuangbin]专题二 搜索进阶 Escape HDU - 3533【BFS】
  8. 秒杀实现原理及实现方式(转)
  9. 使用python登陆dvbbs
  10. 学习先进安全技术理念,RSA 研讨会在京成功举行