【t073】&&【t015】魔法物品
Time Limit: 1 second
Memory Limit: 128 MB
【问题描述】
有两种类型的物品:普通物品和魔法物品。每种普通物品有一个价值P,但每种魔法物品有两种价值:鉴定前的价值P1和鉴定后的
价值P2(保证P2>P1)。
为了鉴定一个魔法物品,你需要购买一个鉴定卷轴。鉴定完一件魔法物品以后,鉴定卷轴便会消失。每个鉴定将会消耗Pi元钱,如
果没有足够的钱,你将无法购买任何鉴定卷轴。
现在,你正在一个集市中,同时拥有很多物品。你知道每件物品的价值并且想要出售全部物品。那么,你最多能够获得多少钱呢?
你可以假定:
? 开始的时候你没有钱。
? 所有的魔法物品都还没有被鉴定。
? 只要你有足够的钱,你可以购买任意多的鉴定卷轴。
【数据规模】
0< Pi<= 5000
0 < P <= 10000
0 < P1 < P2 <= 10000
对于30%的数据 N <= 50,对于100%的数据 N <= 1000
【输入格式】
第一行有两个整数N和Pi,表示你拥有的物品数和一个鉴定卷轴价格。
接下来N行,每行给出一件物品的价格。
对于每件普通物品,那一行仅有一个整数P。
对于每件魔法物品,那一行将会有两个整数P1和P2。
【输出格式】
一个整数表示你最多能够获得多少钱。
Sample Input
2 10
10
20 100
Sample Output
100
【题解】
我们先假定:值得买的魔法物品都买了(即a[2]-a[1] > pi的卷轴),然后它们的价值是a[2]-pi;
只要能买一个鉴定轴,就所有的值得买的魔法物品都可以买了。如果卖掉了所有的普通物品和那些不值得买的魔法物品(当做普通物品卖)所凑的钱还不够买一个鉴定轴。必然要把一些已经鉴定过的魔法卷轴改为不鉴定直接卖掉以此来凑钱买一个鉴定轴。这会损失一些钱。每个值得买的魔法物品变成普通物品会损失a[2]-pi-a[1]点价值。要让损失的价值最少。就要从n个值得买的魔法物品中选出若干个物品。这些物品都有一个重量和价值。重量是它能凑的钱的数(也即a[1],也即普通物品价格),然后价值是它损失的价值。我们要让损失的价值最少。然后这个问题的容量就是所需要凑的钱的数目,也即pi减去那些不值得买的魔法物品和普通物品的价格之和。设其为m;
问题就变成一个容量为m的背包。n个物品。求能使得背包装满的最小价值。
f数组中的下标代表凑的钱的数目,最后我们要获取f[m];然后这是一个0/1背包。要逆序更新。还有一个问题。可能所有的物品不能恰好凑到m,可能会超过m。这样我们就要记录超过了多少。最后要加上去。因为我们只要买一个卷轴就好了。剩下的钱不算是损失的。因为也是通过把魔法物品当做普通物品卖来的。
最后用之前累加的普通物品和魔法物品的和减去f[t]再加上rest[m]即可,(t在够买一个卷轴时为m),rest为这种凑的方案剩下的钱。如果把所有的魔法物品当做普通物品卖掉都不够买一个卷轴,则t!=m。
【代码】
#include <cstdio>
#include <iostream>
#include <string> using namespace std; int n,pi,a[1001][3],num = 0,w[1001],c[1001],f[5001],rest[5001]; int main()
{
//freopen("F:\\rush.txt","r",stdin);
scanf("%d%d",&n,&pi);
for (int i = 1;i <= n;i++)
{
char t = 1;
a[i][0] = 0;
while (t != '\n') //如果没有读完就继续读
{
a[i][0]++; //a[i][0]用来记录第i个物品有几个价格
scanf("%d",&a[i][a[i][0]]);
t = getchar();
}
}
int su = 0,su2 = 0; //su是把所有值得当魔法物品卖的和普通物品的价格的累加的和。
//su2则只是把普通物品的价格的累加起来。 (这里的普通物品包括不值得当魔法物品卖的物品)
for (int i = 1;i <= n;i++) //根据n个物品的信息累加
if (a[i][0] == 1)
su+=a[i][1],su2+=a[i][1];
else
{
if ((a[i][2] - a[i][1]) <= pi)
su+=a[i][1],su2+=a[i][1];
else
{
num++; //把值得当魔法物品卖的物品的信息存储下来
int temp = a[i][2]-pi;
su+=temp;
c[num] = temp-a[i][1]; //所需要损失的价值
w[num] = a[i][1]; //选num物品凑的钱数
} }
if (su2 >= pi) //如果普通物品的累加和够买一个鉴定卷。则直接输出答案。
{ printf("%d",su); //su已经剪掉了买卷轴的钱 }
else
{
int m = pi-su2; //不够买一个卷轴 就获取要凑的钱的数目
for (int i = 0;i <= m;i++)
f[i] = 2100000000/3;
f[0] = 0; //这种是要恰好到达的不能全都置为0
for (int i = 1;i <= num;i++)
for (int j = m;j >=0;j--)
if (f[j] != (2100000000/3)) //如果能够恰好凑到j
{
int ju = (j+w[i]); //尝试选用这个物品凑钱
int re = -1; //这个re用来记录用这个物品凑钱会超过m多少钱
if (ju >= m) //如果大于等于m则记录超过m多少钱
{
ju = m;
re = ju-m;
}
if (f[ju] > f[j] + c[i]) //如果能更新解
{
f[ju] = f[j] + c[i]; //则更新解
if (re !=-1) //且记录其超过m多少钱(如果超过)
{
rest[ju] = re;
}
}
}
int tt = m;
while (f[tt] == 2100000000/3) //这是把所有值得当魔法物品的物品当做普通物品来卖都凑不够钱的情况。
//这样所有的魔法物品都会亏损。
tt--;
printf("%d",su-f[tt]+rest[m]); //减掉亏损的钱然后加上超过m的钱。
}
return 0;
}
【t073】&&【t015】魔法物品的更多相关文章
- 魔法物品(magic.pas/c/cpp)
有两种类型的物品:普通物品和魔法物品.普通物品没有魔法属性,而魔法物品拥有一些魔法属性.每种普通物品有一个价值P,但每种魔法物品有两种价值:鉴定前的价值P.和鉴定后的价值P2(当然,P2总是大于P.) ...
- P1899 魔法物品
题目描述 //又是一个好(nan)题好(nan)题 //首先,普通物品一开始就卖掉就可以,因为它不会增值 //至于魔法物品 //如果一个魔法物品使用了卷轴后的价值减去买卷轴的钱还不如鉴定前的价值高,那 ...
- Phaser开源2d引擎 javascript/html5游戏框架
功能特点(Features) 易维护代码(Easy Asset Loading) Phaser可以加载图片,音频文件,数据文件,文本文件和自动解析精灵图和纹理地图集数据(出口纹理封隔器或Flash C ...
- akoj-1140-英雄联盟阵营
英雄联盟阵营 Time Limit:1000MS Memory Limit:65536KTotal Submit:54 Accepted:16 Description 符文之地——瓦罗兰,作为最大的 ...
- NOIP2016游记(非题解)
去年的比赛现在来发是不是晚了. -------------------------------- Day1-白天 出发啦, 动车购票处一群丧病的又在玩售票机 动车上看到胡神打苍蝇 苍蝇打苍蝇 在车上颓 ...
- 洛谷 P2119 魔法阵
题目描述 六十年一次的魔法战争就要开始了,大魔法师准备从附近的魔法场中汲取魔法能量. 大魔法师有mm个魔法物品,编号分别为1,2,...,m1,2,...,m.每个物品具有一个魔法值,我们用X_iXi ...
- [luogu2119]魔法阵 NOIP2016T4
很好的一道数学推导题 45分做法 $O(N^4)$暴力枚举四个材料 55分做法 从第一个约束条件可得到所有可行答案都是单调递增的,所以可以排序一遍,减少枚举量,可以拿到55分 100分做法 首先可以发 ...
- 洛谷P2119 魔法阵
P2119 魔法阵 题目描述 六十年一次的魔法战争就要开始了,大魔法师准备从附近的魔法场中汲取魔法能量. 大魔法师有m个魔法物品,编号分别为1,2,...,m.每个物品具有一个魔法值,我们用Xi表示编 ...
- P2119 魔法阵
原题链接 https://www.luogu.org/problemnew/show/P2119 YY同学今天上午给我们讲了这个题目,我觉得她的思路很好,特此写这篇博客整理一下. 50分:暴力枚举 ...
随机推荐
- Matrix学习——基础知识
以前在线性代数中学习了矩阵,对矩阵的基本运算有一些了解,前段时间在使用GDI+的时候再次学习如何使用矩阵来变化图像,看了之后在这里总结说明. 首先大家看看下面这个3 x 3的矩阵,这个矩阵被分割成4部 ...
- Flume Sink Processors官网剖析(博主推荐)
不多说,直接上干货! Flume Sources官网剖析(博主推荐) Flume Channels官网剖析(博主推荐) Flume Channel Selectors官网剖析(博主推荐) Flume ...
- 右键菜单→新建→BAT 批处理文件
目的:以前编写BAT,通常新建一个文本,然后另存为 .bat,比较麻烦,那么如何右键新建菜单里添加新建批处理文件呢? 代码如下: @echo offcd /d %temp%echo Windows R ...
- Docker---(8)Docker启动Redis后访问不了
原文:Docker---(8)Docker启动Redis后访问不了 版权声明:欢迎转载,请标明出处,如有问题,欢迎指正!谢谢!微信:w1186355422 https://blog.csdn.net/ ...
- R语言- 基本统计分析
目的: 1.描述性统计分析 2.频数表和;列连表 3.相关系数和协方差 4.t检验 5.非参数统计 在上一节中使用了图形来探索数据,下一步就是给出具体的数据来描述每个变量的分布和关系 1.描述性统计分 ...
- 一个IP建多个Web站点
TCP端口法 由于各种原因,我们有时候需要在一个IP地址上建立多个web站点,在IIS5中,我们可能通过简单的设 置达到这个目标. 在IIS中,每个 Web 站点都具有唯一的.由三个部分组成的标识 ...
- HTTP网络协议(一)
1.了解Web及网络基础 TCP/IP协议族按层次可以分为下面四层: 应用层:决定了向用户提供应用服务时通信的活动,TCP/IP协议族内预存了各类通用的应用服务,比如:FTP(文件传输协议)和DNS( ...
- 简介及环境搭建跑通Hello
简介及环境搭建跑通Hello Spring Spring是一个开放源代码的设计层面框架,他解决的是业务逻辑层和其他各层的松耦合问题,因此它将面向接口的编程思想贯穿整个系统应用.是为了解决企业应用程序开 ...
- 【BZOJ 4199】 [Noi2015]品酒大会
[链接]h在这里写链接 [题意] 给你一个长度为n的字符串s; 标志了每一杯酒; 以及n个数字,表示每一杯酒的美味度ai. 两杯酒(i,j)称为r相似 当且仅当 ...
- Shiro的Web项目配置(转)
Shiro的Web项目配置 一 shiro的学习 二 shiro的java客户端配置 三 关于权限的一些问题 一 shiro的学习 官网和张开涛博客 二 shiro的java客户端配置 1.在web. ...