【每日一题】4978:宠物小精灵之收服

news2025/1/19 10:15:41

目录

一:题目 

二:分析

三:代码实现


一:题目 

0e66c5db88ec7c07e81c9ab090457849.jpeg

一天,小智和皮卡丘来到了小精灵狩猎场,里面有很多珍贵的野生宠物小精灵。小智也想收服其中的一些小精灵。然而,野生的小精灵并不那么容易被收服。对于每一个野生小精灵而言,小智可能需要使用很多个精灵球才能收服它,而在收服过程中,野生小精灵也会对皮卡丘造成一定的伤害(从而减少皮卡丘的体力)。当皮卡丘的体力小于等于0时,小智就必须结束狩猎(因为他需要给皮卡丘疗伤),而使得皮卡丘体力小于等于0的野生小精灵也不会被小智收服。当小智的精灵球用完时,狩猎也宣告结束。

我们假设小智遇到野生小精灵时有两个选择:收服它,或者离开它。如果小智选择了收服,那么一定会扔出能够收服该小精灵的精灵球,而皮卡丘也一定会受到相应的伤害;如果选择离开它,那么小智不会损失精灵球,皮卡丘也不会损失体力。

小智的目标有两个:主要目标是收服尽可能多的野生小精灵;如果可以收服的小精灵数量一样,小智希望皮卡丘受到的伤害越小(剩余体力越大),因为他们还要继续冒险。

现在已知小智的精灵球数量和皮卡丘的初始体力,已知每一个小精灵需要的用于收服的精灵球数目和它在被收服过程中会对皮卡丘造成的伤害数目。请问,小智该如何选择收服哪些小精灵以达到他的目标呢?

输入

输入数据的第一行包含三个整数:N(0 < N < 1000),M(0 < M < 500),K(0 < K < 100),分别代表小智的精灵球数量、皮卡丘初始的体力值、野生小精灵的数量。
之后的K行,每一行代表一个野生小精灵,包括两个整数:收服该小精灵需要的精灵球的数量,以及收服过程中对皮卡丘造成的伤害。

输出

输出为一行,包含两个整数:C,R,分别表示最多收服C个小精灵,以及收服C个小精灵时皮卡丘的剩余体力值最多为R。

样例输入

样例输入1:
10 100 5
7 10
2 40
2 50
1 20
4 20

样例输入2:
10 100 5
8 110
12 10
20 10
5 200
1 110

样例输出

样例输出1:
3 30

样例输出2:
0 100

提示:

对于样例输入1:小智选择:(7,10) (2,40) (1,20) 这样小智一共收服了3个小精灵,皮卡丘受到了70点伤害,剩余100-70=30点体力。所以输出3 30
对于样例输入2:小智一个小精灵都没法收服,皮卡丘也不会收到任何伤害,所以输出0 100

 二:分析

本题是一道 01背包 的扩展题 —— 二维费用01背包问题,其本质和经典01背包没有区别

把 野生小精灵 看做 物品,则将捕捉需要的 精灵球个数 定为 第一费用,皮卡丘要消耗的体力 定为 第二费用

最后答案要求物品数量最多,因此我们可以用状态的属性来表示选择的物品数

7a4fec1a94ef2bdf1b8f075d7b705be7.png

 上图展示的是三维朴素,我们用代码实现的时候将省去第一维(野生小精灵数量),类比最经典的01背包问题

每个小精灵的价值wi可以看成1,这样最后就能得到1+1+1…几只小精灵

注意,题目提到:

①使得皮卡丘体力小于等于0的野生小精灵也不会被小智收服,因此皮卡丘的体力值需在m - 1时开始

②如果可以收服的小精灵数量一样,小智希望皮卡丘受到的伤害越小(剩余体力越大),因此在最后还需要从小到大遍历f[n][i](i = 0,1,...,m-1),当初次与f[n][m-1]相等时即受到的伤害i最小,即剩皮卡丘余体力m - i 最大
 

三:代码实现

#include<bits/stdc++.h>

using namespace std;

int n, m, k;
const int N = 1010, M = 510;
int dp[N][M];

int main()
{
    cin>>n>>m>>k;//精灵球数量、皮卡丘初始的体力值、野生小精灵的数量
    for(int i=1;i<=k;++i)
    {
        int v1, v2;
        cin>>v1>>v2;
        //j,l二维费用,分别为 消耗精灵球数 和 皮卡丘消耗体力数
        for(int j=n;j>=v1;j--)
            for(int l=m-1;l>=v2;l--)//皮卡丘的体力值需在m - 1时开始,原因如上
            dp[j][l] = max(dp[j][l], dp[j-v1][l-v2]+1);
    }
    cout<<dp[n][m-1]<<' ';
    
    int ans = 0;
    //从小到大循环精灵对皮卡丘造成的伤害
    for(int i=0;i<=m-1;++i) if(dp[n][i]==dp[n][m-1]) {ans = i; break;}
    cout<<m-ans<<endl;//跳出循环时ans为最小伤害值,m-ans即为皮卡丘的剩余体力值的最大值
    
    return 0;
}


 

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

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

相关文章

MySql,

SQL语句分类 DDL&#xff1a;数据定义语句【create 表&#xff0c;库...】DML:数据操作语句【增加insert&#xff0c;修改update&#xff0c;删除delete】DQL&#xff1a;数据查询语句【select】DCL&#xff1a;数据控制语句【管理数据库&#xff1a;比如用户权限grant&#xf…

DITA技巧:图支持热点链接

- 1 - 场景 在文档或者手册中&#xff0c;我们常希望用户点击图上的某个对象自动跳转到这个对象的文字说明。 比如&#xff1a;点击下边爆炸图中的数字&#xff0c;跳转到这个数字指向的零件的说明。 比如&#xff1a;点击下图中的按钮&#xff0c;了解每个按钮的功能。 - 2…

2023增长为王,消费者数字化逆向重构消费企业

2023年对于消费企业来说&#xff0c;最大的主题就是回归增长。据不完全统计&#xff0c;2022年关闭的线下门店超过7400家&#xff0c;倒闭的底商不计其数&#xff0c;很多消费上市企业业绩表现不及预期&#xff0c;新上市企业数量和募资额度均减少…… 自从2015年后电商流量红…

大数据Doris(五):FE 扩缩容

文章目录 FE 扩缩容 一、通过MySQL客户端连接Doris 二、FE Follower扩缩容 1、准备 FE 安装包 2、在 node2 、 node3 上修改 fe.conf 配置文件 3、在 node2 、 node3 上启动 FE 4、添加 FE Follower 到 Doris 集群 三、FE Observer 扩缩容 1、准备 FE 安装包 2、在 n…

02 KVM安装虚拟化

文章目录 02 KVM安装虚拟化2.1 最低硬件要求2.2 安装虚拟化核心组件2.2.1 安装方法2.2.1.1 前提条件2.2.1.2 安装步骤 2.2.2 验证安装是否成功 02 KVM安装虚拟化 2.1 最低硬件要求 在openEuler系统中安装虚拟化组件&#xff0c;最低硬件要求&#xff1a; AArch64处理器架构&…

势能回馈系统超级电容储能系统介绍

在港口现有的常规单传动变频驱动系统中&#xff0c;门机在起升机构下降以及其他主要机构减速过程中&#xff0c;下降的势能和制动的动能将产生的再生能量传递给交流电动机后转换成再生电能&#xff0c;而单传动所配置的变频驱动系统通常通过采用制动单元和制动电阻将再生电能转…

一分钟图情论文:《数智时代情报学与情报工作的发展透视》

数智时代情报学与情报工作的发展透视 当前&#xff0c;以人工智能、大数据和云计算为代表的数智技术在社会各个领域的应用中发挥了独特而强大的作用&#xff0c;这对传统的情报学和情报工作带来了巨大的冲击和挑战。然而&#xff0c;这也为情报学和情报工作带来了机遇和发展空…

小白入门之args, *args, **kwargs

目录 一、介绍&#xff1a; 二、实例&#xff1a; 2.1 args 2.2 *args 2.2.1 基础版 2.2.2 进阶版 2.3 **kwargs 2.4 *args 和**kkwargs连用 一、介绍&#xff1a; 首先&#xff0c;不是必须写成*args和**kwargs&#xff0c;只有变量前面星号*才是必须的。也可以写成*…

[前端基础]promise的基本使用(包括async,await语法糖)

目录 1.什么是promise 2.关于promise对象 3.promise常用API 4.promise链式调用 5.async和await语法糖 1.什么是promise 众所周知,在以往,我们处理异步操作主要是通过回调函数处理 setTimeout(()>{},100); 例如这个定时器,异步操作会通过时间循环队列实现. 但是比如说…

PID控制---基于python模拟

PID是控制中非常经典的一个模型&#xff0c;利用P(比例)、I(微分)、D(积分)三者相互合作来实现对一个信号的闭环控制&#xff0c;同时可以让信号波形平滑变化而不是突变。以下主要是结合一个python实现的控制速度的程序来模拟PID的过程。 参考博客&#xff1a;电机控制进阶——…

SOA与中间件、基础件的发展

应运而生的SOA   美国著名的IT市场研究和顾问咨询公司Gartner预测:到2006年&#xff0c;采用面向服务的企业级应用将占全球销售出的所有商业应用产品的80 以上到2008年&#xff0c;SOA将成为绝对主流的软件工程实践方法。近几年全球各大IT巨头纷纷推出自己的面向服务的应用平…

WordPress切换为经典编辑器可视化/文本切换不显示解决方法

WordPress文章编辑器切换为经典编辑器可视化/文本状态无法切换消失的问题有用户遇到过&#xff0c;出现这样的问题时&#xff0c;我们首先应该回忆一下&#xff0c;之前自己进行了哪些操作导致这种情况的出现&#xff0c;比如&#xff1a; 更换了新主题&#xff1f; 安装了新插…

软考高项 - 计算公式汇总整理

大家好&#xff0c;我是陈哈哈&#xff0c;我准备参加23年5月份的软考信息项目管理师考试&#xff0c;学习之余还是习惯做一些重点、考点的记录&#xff0c;用于自己复习&#xff0c;以及分享给日后考试的考友&#xff0c;啥都不说了&#xff0c;祝通过&#x1f339;&#x1f3…

【设计模式】UML类图与软件设计原则

1&#xff0c;设计模式概述 1.1 软件设计模式的产生背景 "设计模式"最初并不是出现在软件设计中&#xff0c;而是被用于建筑领域的设计中。 1977年美国著名建筑大师、加利福尼亚大学伯克利分校环境结构中心主任克里斯托夫亚历山大&#xff08;Christopher Alexand…

Docker基础学习1

Docker 1 Docker简介 1.1 什么是虚拟化 在计算机中&#xff0c;虚拟化&#xff08;英语&#xff1a;Virtualization&#xff09;是一种资源管理技术&#xff0c;是将计算机的各种实体资源&#xff0c;如服务器、网络、内存及存储等&#xff0c;予以抽象、转换后呈现出来&…

数字温度传感器-DS18B20

文章目录 一、DS18B20器件图二、DS18B20特点三、DS18B20内部结构内部构成 四、工作时序1.初始化时序2.ReadOneChar2.WriteOneChar 一、DS18B20器件图 DS18B20的管脚排列&#xff1a; GND为电源地&#xff1b;DQ为数字信号输入&#xff0f;输出端&#xff1b;VDD为外接供电电源…

【车载助手形象系列二】---车载助手数智人形象制作可以使用AI绘图替代?

上期分享了《车载助手形象系列&#xff1a;数智人入门级介绍》&#xff0c;本期主要讲解下数智人形象制作过程 数字人形象 数智人覆盖了卡通、二次元、写实等多元化风格的虚拟形象&#xff0c;可高精度还原表情和躯干动作&#xff0c;提供涵盖人物设计、3D制作、内容制作、IP运…

深度学习之torchvision、多层感知器与激活函数

文章目录 1 torchvision库与加载内置图片数据集2 多层感知器3 激活函数3.1 ReLU激活函数3.2 Sigmoid激活函数3.3 Tanh激活函数3.4 LeakyReLU激活函数 学习笔记 1 torchvision库与加载内置图片数据集 torchvision库是PyTorch中用来处理图像和视频的一个辅助库&#xff0c;提供了…

Docker部署文本语义检索系统

Docker 部署 pipelines服务 需求&#xff1a;基于docker部署百度飞桨公开项目pipelines服务之 端到端文本语义检索系统 项目链接&#xff1a;https://aistudio.baidu.com/aistudio/projectdetail/3351784?channelType0&channel0 代码地址&#xff1a;https://gitee.com/pa…

03 Kubernetes 系统快速入门

课件 Kubernetes 中的 ownerReference 字段用于建立资源之间的所有者关系&#xff0c;即父子关系。这个字段可以用来指定一个资源是另一个资源的所有者。例如&#xff0c;一个 Deployment 可以拥有多个 Pod&#xff0c;这些 Pod 就可以通过 ownerReference 字段引用到对应的 De…