洛谷1156:垃圾陷阱

题目描述:

  • 一头牛在一个井里,深度为\(D(1\leq D\leq100)\)
  • 每过一段时间会往井里投掷一个物品,牛可以选择将其堆起来或者吃掉,吃掉可以增加生命值(生命值随时间慢慢减少),堆起来就离出口更近一些。同时知道牛的初试生命值为\(10\)。
  • 询问如果牛可以爬出井,输出一个整数表示最早什么时候能够爬出;否则输出这头牛最长可以存活多长时间。

输入格式:

  • 第一行输入两个整数\(D\)和\(G\)表示深度和投入井的物品的数量。
  • 加下来\(G\)行,每行输入\(3\)个整数:\(T(0<T\leq100)\),表示物品被投入井中的时间;\(F(1\leq F\leq30)\),表示物品能增加的生命值;\(H(1\leq H\leq25)\),该物品能垫多少高度。

输出格式:

  • 输出一个整数表示答案。

思路:

  • 背包问题
  • 把井的深度看成是背包的容积。
  • 把堆的物品的高度看成是物品的体积,得到的生命值看成是物品的价值。
  • 那么题目的要求就是考虑最快装满背包的时间或者如果装不满就输出价值\(+(items(i).t)\)
  • 首先将投入物品按照时间作为关键字排序。
  • 那么对于牛来说,一件物品有吃掉它或者堆起来两种选择。
  • 设\(f(i,j)\)表示在第\(i\)个物品时,高度为\(j\)的生命值最大值。
    • 初始状态下: \(f(0,0)=10\),其他情况为\(-INF\)(其实这里我有点没搞懂,但是赋0就会wa掉,希望有人能评论区告诉我一下)
    • \(f(i,j)=max(f(i,j), f(i-1,j)+items(i).v-(items(i).t)-items(i-1).t))\)
    • \(f(i,j)=max(f(i,j),f(i-1,j-items(i).h)-(items(i).t-items(i-1).t))\)
  • 那如果可以爬出来,这时候选一个时间最小值。
  • 那如果不能爬出来,那么枚举一下\(f(i,j)\)的情况。

代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn = 110;
const int INF = 0x3f3f3f3f;
int D, G, f[maxn][100+10], ans;
struct Node{
int t, v, h;
}a[maxn]; bool cmp(Node a, Node b){
return a.t < b.t;
} int main()
{
scanf("%d%d", &D, &G);
for(int i = 1; i <= G; i++){
auto &x = a[i];
scanf("%d%d%d", &x.t, &x.v, &x.h);
}
sort(a + 1, a + 1 + G, cmp);
for(int i = 0; i <= G; i++)
for(int j = 0; j <= D; j++) f[i][j] = -INF;
f[0][0] = 10;
for(int i = 1; i <= G; i++)
for(int j = 0; j <= D; j++)
{
if(f[i-1][j] >= a[i].t - a[i-1].t)
f[i][j] = max(f[i][j], f[i-1][j]+a[i].v-(a[i].t-a[i-1].t));
if(f[i-1][j-a[i].h] >= a[i].t-a[i-1].t && j >= a[i].h)
{
f[i][j] = max(f[i][j], f[i-1][j-a[i].h]-(a[i].t-a[i-1].t));
if(j == D)
{
printf("%d\n", a[i].t);
return 0;
}
}
}
ans = -1;
for(int i = 1; i <= G; i++)
for(int j = 0; j <= D; j++)
ans = max(ans, f[i][j] + a[i].t);
cout << ans << endl;
return 0;
}

luogu_1156: 垃圾陷阱的更多相关文章

  1. 洛谷 P1156 垃圾陷阱

    2016-05-31 09:54:03 题目链接 :洛谷 P1156 垃圾陷阱 题目大意: 奶牛掉坑里了,给定坑的深度和方块的个数,每个方块都可以垫脚或者吃掉维持生命(初始为10) 若可以出来,求奶牛 ...

  2. Codevs 1684 垃圾陷阱

    1684 垃圾陷阱 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 卡门--农夫约翰极其珍视的一条Holsteins奶牛--已经落了 ...

  3. <训练赛> 垃圾陷阱

    垃圾陷阱 时间限制: 1 Sec  内存限制: 128 MB提交: 78  解决: 38[提交][状态][讨论版] 题目描述 卡门--农夫约翰极其珍视的一条Holsteins奶牛--已经落了到&quo ...

  4. 【洛谷】P1156 垃圾陷阱【DP】

    P1156 垃圾陷阱 题目描述 卡门――农夫约翰极其珍视的一条Holsteins奶牛――已经落了到“垃圾井”中.“垃圾井”是农夫们扔垃圾的地方,它的深度为D(2≤D≤100)英尺. 卡门想把垃圾堆起来 ...

  5. 【题解】P1156垃圾陷阱

    [题解]P1156 垃圾陷阱 乍看此题,我们感觉状态很多,很复杂. 遇到这类型条件比较多的\(dp\),我们不要首先考虑全部设出来,而是要看到这些状态的本质.而在这道题目中,时间和高度就是关键. 考虑 ...

  6. 洛谷——P1156 垃圾陷阱

    P1156 垃圾陷阱 题目描述 卡门――农夫约翰极其珍视的一条Holsteins奶牛――已经落了到“垃圾井”中.“垃圾井”是农夫们扔垃圾的地方,它的深度为D(2 \le D \le 100)D(2≤D ...

  7. [luogu1156]垃圾陷阱_动态规划_背包dp

    垃圾陷阱 luogu-1156 题目大意:Holsteins在距离地面D英尺的地方,FJ间隔时间ti会往下扔第i个垃圾.Holsteins对待每一个垃圾都会选择吃掉或者垫高.Holsteins有10个 ...

  8. 【2018寒假集训 Day2】【动态规划】垃圾陷阱(挖坑等填,未完成)

    垃圾陷阱 (well) 卡门--农夫约翰极其珍视的一条Holsteins奶牛--已经落了到"垃圾井"中."垃圾井"是农夫们扔垃圾的地方,它的深度为D (2 &l ...

  9. 洛谷P1156 垃圾陷阱[背包DP]

    题目描述 卡门――农夫约翰极其珍视的一条Holsteins奶牛――已经落了到“垃圾井”中.“垃圾井”是农夫们扔垃圾的地方,它的深度为D(2<=D<=100)英尺. 卡门想把垃圾堆起来,等到 ...

随机推荐

  1. Python之路【第二十五篇】:数据库之pymysql模块

    数据库进阶 一.pymysql模块 pymysql是Python中操作Mysql的模块,其使用的方法和py2的MySQLdb几乎相同. 二.pymysql模块安装 pip install pymysq ...

  2. [翻译] InfluxDB 存储机制解析

    原文地址: https://medium.com/dataseries/analysis-of-the-storage-mechanism-in-influxdb-b84d686f3697 TODO

  3. 你读过的最好的 C++ 开源代码是什么?

    LevelDb LevelDb是谷歌两位大神级别的工程师发起的开源项目,简而言之,LevelDb是能够处理十亿级别规模Key-Value型数据持久性存储的C++ 程序库.链接:google/level ...

  4. C# Dapper 的简单实用

    首先引入dapper  PM>Install-Package Dapper -Version 2.0.4 (可能会出现因版本问题而安装失败详情见官网:https://stackexchange. ...

  5. C#生成/调用动态链接库

    参考地址:https://www.cnblogs.com/qq4004229/archive/2013/01/30/2882409.html 一.需求描述 (1)用代码生成动态链接库 (2)用C#代码 ...

  6. JAVA 架构和技术框架百科

    YApi 是高效.易用.功能强大的 api 管理平台,旨在为开发.产品.测试人员提供更优雅的接口管理服务.可以帮助开发者轻松创建.发布.维护 API,YApi 还为用户提供了优秀的交互体验,开发人员只 ...

  7. Web前端2019面试总结4

    1.span标签的width和height分别为多少?     首先span不是块级元素,是不支持宽高的,但是style中有了个float:left:就使得span变成了块级元素支持宽高,height ...

  8. Android-----解析xml文件的三种方式

    SAX解析方法介绍: SAX(Simple API for XML)是一个解析速度快并且占用内存少的XML解析器,非常适合用于Android等移动设备.SAX解析XML文件采用的是事件驱动,也就是说, ...

  9. Mybatis如何插入空字段

    出现异常:SQLException : 无效的类型: 1111 使用Mybatis插入一条记录,某字段设为null,出错 尝试将空的mgr属性插入到数据库,解决办法: 添加setting属性jdbcT ...

  10. Linux指令(压缩和解压类)

    gzip/gunzip 指令 gzip用于压缩文件,gunzip用于解压基本语法: gzip文件 (功能描述:压缩文件,只能将文件压缩为*.gz文件) gunzip文件.gz (功能描述:解压缩文件命 ...