背包系列第六篇----完全背包(求解最大价值的个数)
发布日期:2021-10-03 20:32:35 浏览次数:2 分类:技术文章

本文共 1225 字,大约阅读时间需要 4 分钟。

一:问题

完全背包问题描述:一个容量为V的背包。现在有N种物品,每种物品有无数个,每种物品的体积是C1,C2,…,Cn,对应的每种的价值是W1,W2,…,Wn.。试问,在不超过背包容量的情况下,物品装入背包的最大价值?

和第三篇一样,我们来求出最大价值的个数。

二:分析理解

我们设置num[ i ][ j ]二维数组来表示dp[ i ][ j ]的方案数。

1.dp[ i ][ j ] == dp[ i-1 ][ j ]且dp[ i ][ j ] != dp[ i ][ j-Ci ] + Wi 的时候,num[ i ][ j ] = num[ i-1 ][ j ] ;

2.dp[ i ][ j ] != dp[ i-1 ][ j ]且dp[ i ][ j ] == dp[ i ][ j-Ci ] + Wi 的时候,num[ i ][ j ] = num[ i-1 ][ j-Ci ] ;

3.dp[ i ][ j ] == dp[ i-1 ][ j ]且dp[ i ][ j ] == dp[ i ][ j-Ci ] + Wi 的时候,num[ i ][ j ] = num[ i-1 ][ j ]  + num[ i-1 ][ j-Ci ];

这里可以压缩下num[ i ][ j ],压缩成num[ j ],同dp[ i ][ j ]压缩成dp[ j ]一样。

三:代码

#include
#include
using namespace std;#define N 6#define V 10 //背包容量int w[N + 1] = { 0,1,3,1,4,40,5 }; //6个物品的价值,第一个0除外int v[N + 1] = { 0,4,6,5,1,10,7 }; //6个物品的体积,第一个0除外int dp[V + 5];int num[V + 5];int main(){ fill(num, num + V + 5, 1); for (int i = 1; i <= N; i++) { for (int j = v[i]; j <= V; j++) { if (dp[j] < dp[j - v[i]] + w[i]) { dp[j] = dp[j - v[i]] + w[i]; num[j] = num[j - v[i]]; } else if (dp[j] == dp[j - v[i]] + w[i]) num[j] += num[j - v[i]]; } } printf("最大价值是:%d\n", dp[V]); printf("此时背包的最大价值个数是:%d\n", num[V]); return 0;}
四:数据测试

返回背包系列目录--->

转载地址:https://blog.csdn.net/LaoJiu_/article/details/51286369 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:OpenCV3.0 Beta + Windows10 + Visual Studio 2015 配置
下一篇:背包系列第五篇----完全背包(求解最大价值时背包的物品)

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2024年04月16日 05时28分32秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

【大话Mysql面试】-Mysql索引 2019-04-26
【大话Mysql面试】-Mysql锁 2019-04-26
【大话Mysql面试】-Mysql常见面试题目 2019-04-26
08 【多线程高并发】Java线程间通信的方式 2019-04-26
【数据结构与算法】什么是跳表?通俗易懂来理解跳表 2019-04-26
【数据结构与算法】什么是图?图是什么?快速带你回顾图有关的知识点 2019-04-26
【数据结构与算法】什么是串?什么是KMP算法?字符串匹配是什么? 2019-04-26
【数据结构与算法】什么是布隆过滤器?如何防止缓存穿透的问题? 2019-04-26
【Java锁体系】CopyOnWriteArrayList是什么?线程安全的arraylist是哪个? 2019-04-26
【面试题目】Java设计模式你有哪些了解?说几个常用的。 2019-04-26
【计算机操作系统】常说的死锁是什么?死锁产生的必要条件是什么?死锁的解决策略是什么? 2019-04-26
【计算机操作系统】进程管理详解?进程与线程区别是什么?进程调度的算法有哪些?进程通信有哪些? 2019-04-26
【计算机操作系统】虚拟内存是什么?分页系统地址映射?页面置换算法有哪些?分段地址映射又是什么? 2019-04-26
【计算机操作系统】设备管理?磁盘结构是怎么样的?磁盘调度算法有哪些? 2019-04-26
【多线程高并发】为什么要使用多线程?创建多少个线程合适呢? 2019-04-26
【多线程与高并发】 Java两个线程轮流打印1-100两个数?多线程轮流打印数字? 2019-04-26
【多线程与高并发】 Java两个线程轮流打印字符串? 2019-04-26
【Linux命令篇】Linux命令实践 2019-04-26
【Leetcode单调队列】Leetcode239 滑动窗口最大值 2019-04-26
【Leetcode-单调栈】单调栈相关的题目-下一个更大的元素I 每日温度 2019-04-26