一、0/1背包是什么
一般是问几个物品和一个容积,问最大的价值
二、使用方法
1、0/1背包
一个旅行者有一个最多能用m公斤的背包,现在有n件物品,它们的重量分别是W1,W2,…,Wn,它们的价值分别为C1,C2,…,Cn.若每种物品只有一件求旅行者能获得最大总价值。
一个旅行者有一个最多能用m公斤的背包,现在有n件物品,它们的重量分别是W1,W2,…,Wn,它们的价值分别为C1,C2,…,Cn.若每种物品只有一件求旅行者能获得最大总价值。
输入格式:
第一行:两个整数,M(背包容量,M<=200)和N(物品数量,N<=30);
w 第2..N+1行:每行二个整数Wi,Ci,表示每个物品的重量和价值。
输出格式:
仅一行,一个数,表示最大总价值。
限制:
空间限制:128MByte
时间限制:1秒
样例:
输入:
10 4
2 1
3 3
4 5
7 9
输出:
12
这就是一个标准的0/1背包问题
为了找到这个问题的状态转移方程,我们可以使用刷表法:
刷表法
刷表,顾名思义,就是用一个表记录状态,然后总结自己填表时的思想规律,从而找到状态转移方程
我来举个例子:
这时候是不是就可以得到状态转移方程了
先不急,理一下思路
背包问题,其实就是在选或者不选中选择,如果选,就加上价值后再加上减去重量后可到达的最大值,如果不选,就选择在这个重量下可获得的最大价值
状态转移方程就是:
dp[i][j]=max(dp[i-1][j],dp[i-1][j-w[i]]+v[i]);
代码解:
所以这道题的代码就是:
#include<iostream>
using namespace std;
int dp