01背包
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了01背包相关的知识,希望对你有一定的参考价值。
01背包是动态规划中,最基础也是经典的一个算法之一。
经典题意:
1.有n个不同的物体,有体积为m的一个背包;
2.n个物体分别有自己的体积v,价值c;
输出:
在背包中能装的最大价值
题解:
首先将这n个物体的体积和价值存在两个不同的数组中(v[i],表示第i个物体的体积,c[i]表示第i个物体的价值)
01背包的动态规划方程为:f[i, j]=max( f[i-1 ,j] ,f[i-1, j-v[i]]+c[i]);f[i, j]表示在前 i 件物体中选择若干件放在容量为 j 的背包中可以取得的最大价值。
所以问题就在于第 i 件物品该不该放在背包中。
一维的具体代码:
1 int dp[maxn]; 2 int c[maxn]; 3 int v[maxn]; 4 5 for (int i = 0; i < n; i++) 6 { 7 for (int j = m; j >= v[i]; j--) 8 { 9 dp[j] = max(dp[j], dp[j - v[i]] + c[i]); 10 } 11 }
二维的具体代码:
1 int dp[m + 1][maxn] = { 0 }; 2 int c[maxn]; 3 int v[maxn]; 4 5 for (int i = 0; i < n; i++) 6 { 7 for (int j = m; j >= 0; j--)//此时正序,逆序皆可,因为有i的存在 8 { 9 if (j >= v[i]) 10 dp[i + 1][j] = max(dp[i][j], dp[i][j - v[i]] + c[i]); 11 else 12 dp[i + 1][j] = dp[i][j]; 13 } 14 }
但是有时候题目会变态的问你选择了哪些物体,或者说是选择了哪些路径。参考下位大佬的博客:
http://blog.csdn.net/wumuzi520/article/details/7014559
以上是关于01背包的主要内容,如果未能解决你的问题,请参考以下文章
代码随想录算法训练营第四十二天 | 01背包问题,你该了解这些01背包问题,你该了解这些 滚动数组 416. 分割等和子集