c语言动态规划0-1背包,c++实现0-1背包问题完整源码(动态规划实现)
#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背包问题完整源码(动态规划实现)相关推荐
- C语言二叉树的lowest common ancestor最低公共祖先(附完整源码)
C语言二叉树的lowest common ancestor最低公共祖先 C语言二叉树的lowest common ancestor最低公共祖先完整源码(定义,实现,main函数测试) C语言二叉树的l ...
- C语言二叉搜索树返回key的树级(附完整源码)
C语言二叉搜索树返回key的树级 C语言二叉搜索树返回key的树级完整源码(定义,实现,main函数测试) C语言二叉搜索树返回key的树级完整源码(定义,实现,main函数测试) #include ...
- C语言最简单的sleep sort睡眠排序实现(附完整源码)
C语言最简单的sleep sort睡眠排序实现 C语言最简单的sleep sort睡眠排序实现完整源码(定义,实现,main函数测试) C语言最简单的sleep sort睡眠排序实现完整源码(定义,实 ...
- C语言求在算术级数中找到缺少的数字(附完整源码)
C语言求在算术级数中找到缺少的数字 在算术级数中找到缺少的数字 C语言求在算术级数中找到缺少的数字完整源码(定义,实现,main函数测试) 在算术级数中找到缺少的数字 Examples: Input: ...
- C语言二分法在一个有序数组查找数的算法(附完整源码)
C语言二分法在一个有序数组查找数 二分法在一个有序数组查找数 C语言分治法来计算pow(x,y)完整源码(定义,实现,main函数测试) 二分法在一个有序数组查找数 给定一个排序数组和一个数字. 用户 ...
- C语言通过链表指针删除链表节点的算法(附完整源码)
C语言通过链表指针删除链表节点的算法 C语言通过链表指针删除链表节点的算法完整源码(定义,实现,main函数测试) C语言通过链表指针删除链表节点的算法完整源码(定义,实现,main函数测试) #in ...
- C语言Huffman Encode霍夫曼编码的算法(附完整源码)
C语言Huffman Encode霍夫曼编码的算法 C语言Huffman Encode霍夫曼编码的算法完整源码(定义,实现,main函数测试) C语言Huffman Encode霍夫曼编码的算法完整源 ...
- C语言检查列表是否是回文的算法(附完整源码)
C语言检查列表是否是回文的算法 C语言检查列表是否是回文的算法完整源码(定义,实现,main函数测试) C语言检查列表是否是回文的算法完整源码(定义,实现,main函数测试) #include < ...
- C语言删除单链列表中间的节点的算法(附完整源码)
C语言删除单链列表中间的节点的算法 C语言删除单链列表中间的节点的算法完整源码(定义,实现,main函数测试) C语言删除单链列表中间的节点的算法完整源码(定义,实现,main函数测试) #inclu ...
最新文章
- shell中竖线的作用_如何在 Linux 中安装、配置和使用 Fish Shell?
- RDKit | 基于随机森林(RF)的机器学习模型预测hERG阻断剂活性
- 2021年春季学期-信号与系统-第六次作业参考答案-第五小题
- uva 10047 the monocyle (四维bfs)
- Angular中使用双向数据绑定操作表单的input、checkboc、radio、select、textarea实现简单的人员登记系统实例
- vue学习笔记-01-前端的发展历史(从后端到前端,再到前后端分离,再到全栈)
- 怎么更改Windows11鼠标指针大小和样式
- Mybatis传递多个参数
- .net网页的生命周期列表
- Visio图片导出不清晰
- 五矿系30亿项目未经环评私行上马遭环保部叫停
- Vscode——内置浏览器
- http请求中简单的签名验证
- FZUOJ 2214 Knapsack problem 背包
- 2020年保育员(中级)多少分及格及保育员(中级)模拟考试系统
- java几种对象的区别(PO,POJO,VO,BO,DAO)
- 头牌知产介绍空气炸锅商标转让类别
- Android---App Widget(官方文档翻译)
- 2022年(23届)电子信息/通信工程保研|四非上岸浙大的保研之旅(浙大、中科大、哈工大、东南、南开、西电、成电等)
- 嵌入式系统232串口测试笔记
热门文章
- GeForce 3080更新470驱动出错的解决方案
- java集合数据复制到另外一个集合
- u盘中删除的文件怎样才能恢复呢?
- 计算机科学梗,只有本专业的人才明白的梗,你看懂了几个?
- SuperMap GIS三维插件使用QA
- 5000学软件测试买什么电脑好,大学学的软件工程,买什么电脑合适,预算不超过7000?...
- [kuangbin]专题二 搜索进阶 Escape HDU - 3533【BFS】
- 秒杀实现原理及实现方式(转)
- 使用python登陆dvbbs
- 学习先进安全技术理念,RSA 研讨会在京成功举行