acwing算法提高之动态规划--背包模型(三)

目录

  • 1 基础知识
  • 2 模板
  • 3 工程化

1 基础知识

暂无。。。

2 模板

暂无。。。

3 工程化

题目1:潜水员。

解题思路:DP。

状态定义f[i][j][k]:从前i个物品中选,氧气至少为j,氮气至少为k的最小方案数。

状态转移,以下情况的最小值,

  1. 不选择第i个物品,即f[i-1][j][k]
  2. 选择第i个物品,即f[i - 1][j - v1[i]][k - v2[i]] + w[i]。(状态从i-1层转移过来的,故从大到小循环。)

同样地,可以将状态优化到二维。

初始化,f[i][j] = 0x3f3f3f3ff[0][0] = 0

最终答案,返回f[n][m]

C++代码如下,

#include <iostream>
#include <cstring>using namespace std;const int N = 30, M = 90;
int n, m, k;
//n表示氧气需要的量
//m表示氮气需要的量
//k表示气缸的个数
int f[N][M];int main() {memset(f, 0x3f, sizeof f);f[0][0] = 0;cin >> n >> m >> k;while (k--) {int a, b, c;cin >> a >> b >> c;for (int i = n; i >= 0; --i) {for (int j = m; j >= 0; --j) {f[i][j] = min(f[i][j], f[max(i - a, 0)][max(j - b, 0)] + c);}}}cout << f[n][m] << endl;return 0;
}

题目2:背包问题求解具体方案数。

解题思路:求具体方案数不难,关键是求解字典序最小的,有些困难。

C++代码如下,

#include <iostream>using namespace std;const int N = 1010;
int n, m;
int v[N], w[N];
int f[N][N];int main() {cin >> n >> m;for (int i = 1; i <= n; ++i) cin >> v[i] >> w[i];for (int i = n; i >= 1; --i) {for (int j = 0; j <= m; ++ j) {f[i][j] = f[i + 1][j];if (j >= v[i]) f[i][j] = max(f[i][j], f[i + 1][j - v[i]] + w[i]);}}int j = m;for (int i = 1; i <= n; ++i) {if (j >= v[i] && f[i][j] == f[i + 1][j - v[i]] + w[i]) {cout << i << " ";j -= v[i];}}return 0;
}

题目3:机器分配。

解题思路:分组背包问题求解最大价值和具体方案。

C++代码如下,

#include <iostream>using namespace std;const int N = 20;
int n, m;
int w[N][N]; //第i组第k台的价值
int f[N][N];
int s[N]; //第i组选了第多少台int main() {cin >> n >> m;for (int i = 1; i <= n; ++i) {for (int k = 1; k <= m; ++k) {cin >> w[i][k];}}for (int i = 1; i <= n; ++i) {for (int j = 0; j <= m; ++j) {f[i][j] = f[i-1][j];for (int k = 1; k <= m; ++k) {if (j >= k) {f[i][j] = max(f[i][j], f[i-1][j - k] + w[i][k]);}}}}cout << f[n][m] << endl;int j = m;for (int i = n; i >= 1; --i) {for (int k = 1; k <= m; ++k) {if (j >= k && f[i][j] == f[i-1][j - k] + w[i][k]) {s[i] = k;j -= k;break;}}}for (int i = 1; i <= n; ++i) {cout << i << " " << s[i] << endl;}return 0;
}

题目4:金明的预算方案。

解题思路:分组背包问题。

C++代码如下,

#include <iostream>
#include <vector>
#include <unordered_map>using namespace std;const int M = 32010;
int n, m;
int f[M];int main() {cin >> m >> n;//读入n个物品struct ITEM {ITEM(int a, int b) : v(a), w(b) {} //构造函数int v;//体积int w;//价格};vector<ITEM> items;items.emplace_back(ITEM(-1,-1));unordered_map<int, vector<int>> son; //son[i]表示物品i的附件们for (int i = 1; i <= n; ++i) {int v, p, q;cin >> v >> p >> q;ITEM item(v, p * v);items.emplace_back(item);if (q == 0) {//第i件物品是主件son[i].emplace_back(-1);son[i].pop_back();} else {//第i件物品是附件,它的主件是qson[q].emplace_back(i);}}//分组背包问题求解for (auto [i, vec] : son) {//遍历每一个主件i,和它的附件vecfor (int j = m; j >= 0; --j) {//考虑每一个附件for (int k = 0; k < 1 << vec.size(); ++k) {int v = items[i].v, w = items[i].w;//遍历每个附件for (int ii = 0; ii < vec.size(); ++ii) {if (k >> ii & 1) {//选择了第ii个附件v += items[vec[ii]].v;w += items[vec[ii]].w;}}if (j >= v) f[j] = max(f[j], f[j - v] + w);}}}cout << f[m] << endl;return 0;
}

题目5:开心的金明。

解题思路:01背包问题即可。

C++代码如下,

#include <iostream>using namespace std;const int M = 30010;
int n, m;
int f[M];int main() {cin >> m >> n;for (int i = 1; i <= n; ++i) {int v, p;cin >> v >> p;int w = v * p;for (int j = m; j >= v; --j) {f[j] = max(f[j], f[j - v] + w);}}cout << f[m] << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/213064.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解决idea 通过build project 手动触发热部署失败

在debug运行项目的过程中&#xff0c;并且保证&#xff08;不添加方法&#xff0c;不修改方法名&#xff09;一定的规则的情况下&#xff0c;可以通过build project 来手动热部署项目&#xff0c;也就是会交换class文件与resouces文件。 设置项 Edit Configurations Modify Op…

计算机图形学理论(1):建模基础

本系列根据国外一个图形小哥的讲解为本&#xff0c;整合互联网的一些资料&#xff0c;结合自己的一些理解。 场景的组成部分 场景相当于一个或多个模型的集合。模型包含以下内容&#xff1a; 结构描述&#xff1a;几何形状&#xff0c;如顶点、纹理坐标等表面描述&#xff1a…

Vue3中的defineModel

目录 一、vue3的defineModel介绍 二、defineModel使用 &#xff08;1&#xff09;在vite.config.js中开启 &#xff08;2&#xff09;子组件 &#xff08;3&#xff09;父组件 一、vue3的defineModel介绍 为什么要使用到defineModel呢&#xff1f;这里有这样一种场景&…

“快速排序:一种美丽的算法混沌”(1.hoare)

欢迎来到我的博客&#xff01;在今天的文章中&#xff0c;我将采用一种独特且直观的方式来探讨我们的主题&#xff1a;我会使用一幅图像来贯穿整篇文章的讲解。这幅精心设计的图表不仅是我们讨论的核心&#xff0c;也是一个视觉辅助工具&#xff0c;帮助你更深入地理解和掌握本…

学习深度强化学习---第2部分----RL动态规划相关算法

文章目录 2.1节 动态规划简介2.2节 值函数与贝尔曼方程2.3节 策略评估2.4节 策略改进2.5节 最优值函数与最优策略2.6节 值迭代与策略迭代2.7节 动态规划求解最优策略 本部分视频所在地址&#xff1a;深度强化学习的理论与实践 2.1节 动态规划简介 态规划有两种思路&#xff1…

前端 Web Workers 简介

简介 以前我们总说&#xff0c;JS 是单线程没有多线程&#xff0c;当 JS 在页面中运行长耗时同步任务的时候就会导致页面假死影响用户体验&#xff0c;从而需要设置把任务放在任务队列中&#xff1b;执行任务队列中的任务也并非多线程进行的&#xff0c;然而现在 HTML5 提供了…

App备案、ios备案Bundle ID查询、公钥信息、SHA-1值

App备案、ios备案Bundle ID查询、公钥信息、SHA-1值 Bundle ID这个就不说了&#xff0c;都知道是啥&#xff0c;主要说公钥信息和SHA-1值的获取 打开钥匙串访问&#xff0c;找到当前需要备案App的dis证书&#xff0c;如下&#xff1a; #####右键点击显示简介 #####可以看…

03.仿简道云公式函数实战-QLExpress初探

1. 前言 在上一篇文章中&#xff0c;我们简单介绍了一下表达式引擎&#xff0c;并引出我们的主角QLExpress.在这篇文章中&#xff0c;我们先来一个QLExpress的热身。 2. 初探QLExpress 源码地址&#xff1a;https://github.com/alibaba/qlExpress 笔者下载源码的版本是3.3.…

STL源码剖析笔记——适配器(adapters)

系列文章目录 STL源码剖析笔记——迭代器 STL源码剖析笔记——vector STL源码剖析笔记——list STL源码剖析笔记——deque、stack&#xff0c;queue STL源码剖析笔记——Binary Heap、priority_queue STL源码剖析笔记——AVL-tree、RB-tree、set、map、mutiset、mutimap STL源…

【Spring 基础】00 入门指南

【Spring 基础】00 入门指南 文章目录 【Spring 基础】00 入门指南1.简介2.概念1&#xff09;控制反转&#xff08;IoC&#xff09;2&#xff09;依赖注入&#xff08;DI&#xff09; 3.核心模块1&#xff09;Spring Core2&#xff09;Spring AOP3&#xff09;Spring MVC4&…

php实现截取姓名中的第一个字作为头像的实战记录

php 截取中文字符串第一个字 substr 函数 在 PHP 中&#xff0c;使用 substr 函数来截取中文字符串的第一个字。由于 PHP 默认的字符编码是 UTF-8&#xff0c;它可以正确处理中文字符。 $chineseString "你好世界"; $firstChar substr($chineseString, 0, 1); e…

vue2 组件内路由守卫使用

1、beforeRouteEnter 进入页面 to – 即将要跳转到的页面 form – 跳转前的页面&#xff0c;从哪个页面跳转过来的 next – 下一步&#xff0c;若无指定跳转的路由&#xff0c;设置为空 next() 即可 beforeRouteEnter(to, from, next) {next() }, 使用 beforeRouteEnter 时&…

中文分词演进(查词典,hmm标注,无监督统计)新词发现

查词典和字标注 目前中文分词主要有两种思路&#xff1a;查词典和字标注。 首先&#xff0c;查词典的方法有&#xff1a;机械的最大匹配法、最少词数法&#xff0c;以及基于有向无环图的最大概率组合&#xff0c;还有基于语言模型的最大概率组合&#xff0c;等等。 查词典的方法…

知识产权服务企业网站建设效果如何

知识产权服务也有较高的市场需求度&#xff0c;尤其如今互联网深入到各个行业&#xff0c;无论个人还是企业都会以不同的方式经营&#xff0c;相应的为保障自身权益&#xff0c;注册商标、专利等自然不可少&#xff0c;而对普通小白来说&#xff0c;想要完成这些流程也是有些难…

Python实现获取b站视频的弹幕内容

前言 本文是该专栏的第39篇,后面会持续分享python的各种干货知识,值得关注。 在本专栏之前,有详细介绍使用python增加b站视频的播放量方法,感兴趣的同学可往前翻阅《Python-增加b站视频播放量》。而本文,笔者再来单独的详细介绍,通过python来获取b站视频的弹幕内容。如下…

CGAL的3D皮肤表面网格

1、介绍 Edelsbrunner 引入的皮肤表面和具有丰富而简单的组合和几何结构&#xff0c;使其适合在生物计算中模拟大分子。 对这些表面进行网格划分通常是进一步处理其几何形状所必需的&#xff0c;例如在数值模拟和可视化中。 皮肤表面由一组加权点&#xff08;输入球&#xff09…

力扣labuladong——一刷day70

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、力扣814. 二叉树剪枝二、力扣1325. 删除给定值的叶子节点 前言 这道题的难点在于要一直剪枝&#xff0c;直到没有值为 0 的叶子节点为止&#xff0c;只有从…

RecursionError: maximum recursion depth exceeded in comparison

诸神缄默不语-个人CSDN博文目录 这个bug的产生原因是运行rouge包时句子太长&#xff0c;所以递归次数过多了。完整的报错信息懒得粘了&#xff0c;总之很长&#xff0c;解决方案就是手动在程序开始处就增大递归次数&#xff1a; import sys sys.setrecursionlimit(100000)具体…

html通过CDN引入Vue使用Vuex以及Computed、Watch监听

html通过CDN引入Vue使用Vuex以及Computed、Watch监听 近期遇到个需求&#xff0c;就是需要在.net MVC的项目中&#xff0c;对已有的项目的首页进行优化&#xff0c;也就是写原生html和js。但是咱是一个写前端的&#xff0c;写html还可以&#xff0c;.net的话&#xff0c;开发也…

K8S学习指南-minikube的安装

简介 Minikube 是一个用于在本地开发环境中运行 Kubernetes 集群的工具。它允许开发人员在单个节点上体验 Kubernetes&#xff0c;无需配置复杂的生产环境。本指南将详细介绍在 Windows、CentOS 和 Ubuntu 系统上安装 Minikube 的步骤。 1. Windows 系统安装 1.1 &#xff1…