ssl2290-潜水员【dp之二维费用】

其实这是一道例题,但确实是我做过最难(其他的水到炸)的一道二维费用


Description
潜水员为了潜水要使用特殊的装备。他有一个带2种气体的气缸:一个为氧气,一个为氮气。让潜水员下潜的深度需要各种的数量的氧和氮。潜水员有一定数量的气缸。每个气缸都有重量和气体容量。潜水员为了完成他的工作需要特定数量的氧和氮。他完成工作所需气缸的总重的最低限度的是多少?
例如:潜水员有5个气缸。每行三个数字为:氧,氮的(升)量和气缸的重量:
3 36 120
10 25 129
5 50 250
1 45 130
4 20 119
如果潜水员需要5升的氧和60升的氮则总重最小为249 (1,2或者4,5号气缸)。
你的任务就是计算潜水员为了完成他的工作需要的气缸的重量的最低值。


Input
从文本文件gas.in中读入数据。
第一行有2整数t,a(1<=t<=21,1<=a<=79)。它们表示氧,氮各自需要的量。
第二行为整数n (1<=n<=1000)表示气缸的个数。
此后的n行,每行包括ti,ai,wi(1<=ti<=21,1<=ai<=79,1<=wi<=800)3整数。这些各自是:第i个气缸里的氧和氮的容量及汽缸重量。

Output

仅一行包含一个整数,为潜水员完成工作所需的气缸的重量总和的最低值。

Sample Input
5 60
5
3 36 120
10 25 129
5 50 250
1 45 130
4 20 119

Sample Output
249

解题思路

  因为这里是求最小值,所以这里我就反推吧。emmmmmmmmmmmmmm?


代码

#include<cstdio>
#include<iostream>
using namespace std;
int v,u,n,vh[1001],uh[1001],w[1001];
int f[101][101];
int main()
{memset(f,127,sizeof(f));f[0][0]=0;scanf("%d%d%d",&v,&u,&n);for (int i=1;i<=n;i++) scanf("%d%d%d",&vh[i],&uh[i],&w[i]);//输入for (int i=1;i<=n;i++)for (int j=v;j>=0;j--)for (int k=u;k>=0;k--)//循环两个费用{int t1=j+vh[i],t2=k+uh[i];//反推if (t1>v) t1=v;//避免过大if (t2>u) t2=u;//避免过大f[t1][t2]=min(f[t1][t2],f[j][k]+w[i]);//求最小值}printf("%d",f[v][u]);
}

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

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

相关文章

mybatis三种(查询,参数传递)

MyBatis中三种查询方式 Mapper文件代码 <mapper namespace"com.java.mapper.FlowerMapper"> <select id"selectAll" resultType"flower"> select * from flower </select> <select i…

《走遍中国》珍藏版(十一)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");嶙峋怪石与…

.net Kafka.Client多个Consumer Group对Topic消费不能完全覆盖研究总结(一)

我们知道Kafka支持Consumer Group的功能&#xff0c;但是最近在应用Consumer Group时发现了一个Topic 的Partition不能100%覆盖的问题。 程序部署后&#xff0c;发现Kafka在pdb组的consumer消费topic时存在问题&#xff0c;consumer无法完全覆盖Topic的各个partition。如下图&…

JavaFX UI控件教程(八)之Choice Box

翻译自 Choice Box 本章介绍了选项框&#xff0c;这些UI控件提供了在几个选项之间快速选择的支持。 使用ChoiceBox该类将选择框添加到JavaFX应用程序。其简单的实现如图7-1所示。 图7-1创建包含三个项目的选择框 创建一个选择框 例7-1创建了一个包含三个项目的选择框。 例…

乱码问题产生的原因与解决方案---UTF-8

乱码产生的原因 世界上存在着多种编码方式&#xff0c;同一个二进制数字可以被解释成不同的符号。因此&#xff0c;要想打开一个文本文件&#xff0c;就必须知道它的编码方式&#xff0c;否则用错误的编码方式解读&#xff0c;就会出现乱码。 解决办法 Unicode&#xff1a;一…

背包例题【dp练习】

ssl2289-庆功会 Description 为了庆贺班级在校运动会上取得第一名的成绩&#xff0c;班主任决定开一场庆功会&#xff0c;为此拔款购买奖品奖励运动员&#xff0c;期望拔款金额能购买最大价值的奖品&#xff0c;可以补充他们的精力和体力。 Input 第一行二个数n(n<500)&…

MyBatis中Mapper代理方式

Mapper 的动态代理作用 目前使用sqlsession进行增删改查的缺点&#xff1a; [1]没有办法实现多参数的传递 [2]书写的时候没有接口&#xff0c;后期的维护就比较的低 解决的方案&#xff1a; Mapper的代理方式实现增删改查 接口代码 public interface FlowerMapper {//查询所有…

《走遍中国》珍藏版(十二)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");这里的水底…

View Components as Tag Helpers,离在线模板编辑又进一步

在asp.net core mvc中增加了ViewComponent&#xff08;视图组件&#xff09;的概念&#xff0c;视图组件有点类似部分视图&#xff0c;但是比部分视图功能更加强大&#xff0c;它更有点像一个控制器。 使用方法 1&#xff0c;定义类派生自ViewComponent类 2&#xff0c;增加…

JavaFX UI控件教程(九)之Text Field

翻译自 Text Field 本章讨论文本字段控件的功能。 的TextField类实现接受并显示文本输入的UI控制。它提供了从用户接收文本输入的功能。与另一个文本输入控件一起&#xff0c;PasswordField此类扩展了TextInput类&#xff0c;它是通过JavaFX API提供的所有文本控件的超类。…

VS

&—逻辑与 | —逻辑或 &#xff01;—逻辑非 && —短路与 || —短路或 ^ —逻辑异或

MyBatis中动态SQL

01为什么使用sql语句的动态拼接 目前学习的内容sql语句都是直接写死的&#xff0c;但是在实际的开发过程中很多的sql语句都是根据不同的业务情况进行不同的改变的 02 解决的方案 sql语句的动态拼接 03学习的标签 if where when set trim foreach bind include sql 接口代码1 p…

ssl1643-最小乘车费用【dp练习】

最小乘车费用 题目 假设某条街上每一公里就有一个公共汽车站&#xff0c;并且乘车费用如下表&#xff1a;      而任意一辆汽车从不行驶超过10公里。某人想行驶n公里&#xff0c;假设他可以任意次换车&#xff0c;请你帮他找到一种乘车方案&#xff0c;使得总费用最小 …

JavaFX UI控件教程(十)之Scroll Bar

翻译自 Scroll Bar 本章介绍如何使用滚动条控件创建可滚动窗格。 本ScrollBar类可以在应用程序中创建滚动窗格和意见。图9-1显示了滚动条的三个区域&#xff1a;拇指&#xff0c;右侧和左侧按钮&#xff08;或向下和向上按钮&#xff09;以及轨道。 图9-1滚动条的元素 创建…

《走遍中国》珍藏版(十三)

Console.WriteLine("上一本书已经看完&#xff0c;从今天开始看下一本"); System.out.println("《走遍中国》珍藏版"); System.out.println("这本书是关于地理的"); System.out.println("地理往往是和历史进行紧密联系的");一游衡山&a…

a+=b不一定等于a=a+b

说明不会改变本身变量的数据类型与&#xff0c;–运算符一样

Jexus部署.Net Core项目

Jexus Jexus 即 Jexus Web Server&#xff0c;简称JWS&#xff0c;是Linux平台上 的一款ASP.NET WEB服务器。它是 Linux、Unix、FreeBSD 等非Windows系统架设 ASP.NET WEB 服务器的核心程序。 将HTTP自宿主应用程序&#xff08;如Asp.net Core应用程序、Node.js应用程序等&…

MyBatis中增删改操作

Mapper层代码 <!-- 增加操作 public int insert (Flower fl) --> <insert id"insert"> insert into flower values(default,#{name},#{price},#{production}) </insert> <!--修改操作 public int update(…

JavaFX UI控件教程(十一)之Scroll Pane

翻译自 Scroll Pane 在本章中&#xff0c;您将学习如何在JavaFX应用程序中构建滚动窗格。 滚动窗格提供UI元素的可滚动视图。此控件使用户可以通过平移视口或使用滚动条来滚动内容。具有默认设置和添加的图像的滚动窗格如图10-1所示。 图10-1滚动窗格 创建滚动窗格 示例10…

洛谷【P2758】-编辑距离

题目描述 设A和B是两个字符串。我们要用最少的字符操作次数&#xff0c;将字符串A转换为字符串B。这里所说的字符操作共有三种&#xff1a; 1、删除一个字符&#xff1b; 2、插入一个字符&#xff1b; 3、将一个字符改为另一个字符&#xff1b; &#xff01;皆为小写字母&…