当前位置: 首页 > news >正文

备战蓝桥杯 Day10(背包dp)

01背包问题

1267:【例9.11】01背包问题

【题目描述】

一个旅行者有一个最多能装 M� 公斤的背包,现在有 n� 件物品,它们的重量分别是W1,W2,...,Wn�1,�2,...,��,它们的价值分别为C1,C2,...,Cn�1,�2,...,��,求旅行者能获得最大总价值。

【输入】

第一行:两个整数,M�(背包容量,M<=200�<=200)和N�(物品数量,N<=30�<=30);

第2..N+12..�+1行:每行二个整数Wi,Ci��,��,表示每个物品的重量和价值。

【输出】

仅一行,一个数,表示最大总价值。

【输入样例】

10 4
2 1
3 3
4 5
7 9

【输出样例】

12

方法一:搜索(时间复杂度高--O(2^n)) 

#include<iostream>
using namespace std;
const int N = 30;
int m,n,v[N], w[N];
int mx;
bool vis[N];//标记
//搜索状态curV当前已选物品的总价值,curW当前已选物品的总重量
void dfs(int curV, int curW,int dep) {if (curW > m) return;//拦截非法的curVmx = max(mx, curV);//5.通用终止条件if (dep == n + 1)  return;//一共n件物品,n件物品已经搜完了,结束//找出搜索所有方案里面的最大价值//1.枚举方案for (int i = 1; i <= n; i++) {//2.判断标记-防止重复搜索if (!vis[i]) {//3.标记+搜索vis[i] = 1;dfs(curV + v[i], curW + w[i], dep + 1);//4.回溯vis[i] = 0;}}
}
int main() {cin >> m >> n;for (int i = 1; i <= n; i++) {cin >> w[i] >> v[i];}dfs(0, 0, 1);//初始状态cout << mx << endl;return 0;
}

方法二dp

#include<iostream>
using namespace std;
const int N = 30, M = 2e2 + 10;
int m,n,v[N], w[N];
int dp[N][M];
/*
01背包
特点:n件物品,每件物品只有一件,要么选(1),要么不选(0)
朴素版本
状态 dp[i][j] 前i件物品在背包容量不超过j的前提下构成的最大价值
状态转移方程 if(j<w[i]) dp[i][j]=dp[i-1][j];//放不下,不放
else if(j>=w[i]) dp[i][j]=max(dp[i-1][j-w[i]]+v[i]放,dp[i-1][j]不放)//可以放
滚动数组优化
dp[]
*/
int main() {cin >> m >> n;for (int i = 1; i <= n; i++) cin >> w[i] >> v[i];//时间复杂度O(n^2)for (int i = 1; i <= n; i++) {for (int j = 1; j <= m; j++) {if (j < w[i]) dp[i][j] = dp[i - 1][j];//放不下,不放//                                        放1                    不放0else if (j >= w[i]) dp[i][j] = max(dp[i - 1][j - w[i]] + v[i], dp[i - 1][j]);//可以放}}cout << dp[n][m] << endl;return 0;
}

http://www.lryc.cn/news/306227.html

相关文章:

  • Sora 使用教程,新手小白可用
  • 【洛谷千题详解】P1031 均分纸牌
  • 基于文本提示和语义分割的快速抠图
  • 什么是媒体发稿?发稿媒体分类及发稿流程
  • 安全测试自学手册之软件安全测试基础
  • 【LeetCode】升级打怪之路 Day 04:链表 part 2
  • JAVA编程题系列——涵盖几乎所有java内容
  • 【Android12】Monkey压力测试源码执行流程分析
  • Java架构师之路八、安全技术:Web安全、网络安全、系统安全、数据安全等
  • Codeforces Round 240 (Div. 1) C. Mashmokh and Reverse Operation(分治+逆序对)
  • SpringBoot源码解读与原理分析(三十二)SpringBoot整合JDBC(一)JDBC组件的自动装配
  • petalinux_zynq7 驱动DAC以及ADC模块之五:nodejs+vue3实现web网页波形显示
  • Android java中内部类的使用
  • llm的inference(二)
  • pytorch -- torch.nn.Module
  • Microsoft Edge 越用越慢、超级卡顿?网页B站播放卡顿?
  • XGB-9: 分类数据
  • FreeRTOS学习第8篇--同步和互斥操作引子
  • c++STL容器的使用(vector, list, map, set等),c++STL算法的理解与使用(sort, find, binary_search等)
  • 选择VR全景行业,需要了解哪些内容?
  • 830. 单调栈
  • H5 个人引导页官网型源码
  • 【Linux】部署前后端分离项目---(Nginx自启,负载均衡)
  • WPF Style样式设置
  • 【STM32】软件SPI读写W25Q64芯片
  • 普通中小学校管理信息系统V1.1
  • 中国水果采摘机器人行业市场研究及发展趋势分析报告
  • Linux多进程与信号
  • Self-attention与Word2Vec
  • 【Flutter/Android】运行到安卓手机上一直卡在 Running Gradle task ‘assembleDebug‘... 的终极解决办法