DP专题9 理解01背包问题

本题链接:晴问算法

题目:

样例:

输入
5 8
3 5 1 2 2
4 5 2 1 3

输出
10

思路:

        对于 01 背包问题,我们需要明确 DP 数组的含义,这里 经典的 01 背包问题可以用 二维DP进行表示。

        即:  dp[ i ][ j ] ,   其中  i   表示的是 物品编号  j   表示背包容量   ,  dp[ i ][ j ] 表示最大价值

01 背包的递推公式为 :

dp[i][j] = max ( dp[ i - 1][ j ] , dp[ i - 1 ][ j - w[ i ] ] + c[ i ] );

递推公式的含义是

拿取 i 物品时,背包容量为 j 的时候  =  

max (上一个 物品状态(i - 1)容量为 j 的时候的价值  , 

上一个 物品状态(i - 1)容量为 j 的时候的价值 现在取  当前物品 i 所得到的价值 + c[i] ) 


/*  哪个最大价值 就是取哪个  */

AC代码如下:

#include <iostream>
#include <vector>
#include <queue>
#include <cstring>
#include <algorithm>
#include <unordered_map>
#define endl '\n'
#define int long long
#define YES puts("YES")
#define NO puts("NO")
#define umap unordered_map
#define All(x) x.begin(),x.end()
#pragma GCC optimize(3,"Ofast","inline")
#define IOS std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
using namespace std;
const int N = 2e6 + 10;


inline void solve()
{
	int n,m;
	cin >> n >> m;
	
	vector<int>w(n + 1,0),c(n + 1,0);
	vector<vector<int>>dp(n + 1,vector<int>(m + 1,0));
	
	
	for(int i = 1;i <= n;++i) cin >> w[i];
	for(int i = 1;i <= n;++i) cin >> c[i];
	
	for(int i = 1;i <= n;++i)
	{
		for(int j = m;j >= w[i];--j)
		{
			dp[i][j] = max(dp[i - 1][j],dp[i - 1][j - w[i]] + c[i]);
		}
	}
	cout << dp[n][m] << endl;
}

signed main()
{
//	freopen("a.txt", "r", stdin);
	IOS;
	int _t = 1;
//	cin >> _t;
	while (_t--)
	{
		solve();
	}

	return 0;
}

最后提交:

相关推荐

  1. 01背包问题dp

    2024-01-07 08:08:05       21 阅读
  2. 01背包dp问题

    2024-01-07 08:08:05       10 阅读
  3. 01背包问题

    2024-01-07 08:08:05       15 阅读
  4. 01 背包问题(c++)

    2024-01-07 08:08:05       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-07 08:08:05       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-07 08:08:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-07 08:08:05       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-07 08:08:05       20 阅读

热门阅读

  1. 完美的异步处理数据训练神经网络框架

    2024-01-07 08:08:05       37 阅读
  2. HTML中网页缩放配置mete-viewport

    2024-01-07 08:08:05       37 阅读
  3. Eureka工作原理详解

    2024-01-07 08:08:05       35 阅读
  4. 第28关 k8s监控实战之Prometheus(三)

    2024-01-07 08:08:05       40 阅读
  5. 解决2023新版Edge浏览器页面加载不出来问题

    2024-01-07 08:08:05       47 阅读
  6. initrd(4) - Linux man page initrd(4) - Linux 手册页

    2024-01-07 08:08:05       29 阅读
  7. 53、Flink 的Broadcast State 模式介绍及示例

    2024-01-07 08:08:05       29 阅读
  8. linux离线和在线安装docker

    2024-01-07 08:08:05       39 阅读
  9. 如何使用RESTful API构建 web 应用程序

    2024-01-07 08:08:05       32 阅读