洛谷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. lazyload的使用方法

    http://blog.csdn.net/peidandan/article/details/8107634

  2. c# mvc webapi的put报405错误

    程序在本机调试可正常修改,本机是iis11 放到服务器上,报错了:405.服务器iis7.0 返回的错误页面: <!DOCTYPE html PUBLIC "-//W3C//DTD X ...

  3. 图像上划矩形(cv.line()函数)

    在图像上划矩形 import numpy as npimport cv2 as cvimg=np.zeros((400,400),np.uint8)cv.line(img,(100,100),(350 ...

  4. Vue笔记目录

    Vue笔记目录 一.Vue.js介绍 二.vue基础-vue-cli(vue脚手架) ...持续更新中,敬请期待

  5. 为什么会有jQuery、Dojo、Ext、Prototype、YUI、Zepto这么多JS包?

    目前流行的JS框架很多Dojo .Scriptaculous .Prototype .yui-ext .Jquery .Mochikit.mootools .moo.fx 等.当然还有很多我都不熟悉的 ...

  6. iOS之Category关联属性

    Objective-C /** 原文件 */ // Person.h #import <Foundation/Foundation.h> @interface Person : NSObj ...

  7. Windows Server 2012 R2 远程桌面自动设置为不允许连接问题解决方案

    用“gpedit.msc”调出策略组设置窗口,在策略组界面点击:计算机配置->管理模块->Windows组件->远程桌面服务->远程桌面会话主机->连接->允许用户 ...

  8. Linux下源码编译php7

    1.安装依赖包 yum install -y gcc gcc-c++ make zlib zlib-devel pcre pcre-devel libjpeg libjpeg-devel libpng ...

  9. JAVA线程池的创建与使用

    为什么要用线程池? 我们都知道,每一次创建一个线程,JVM后面的工作包括:为线程建立虚拟机栈.本地方法栈.程序计数器的内存空间(下图可看出),所以线程过多容易导致内存空间溢出.同时,当频繁的创建和销毁 ...

  10. VS创建C工程

    打开VS编辑器: 填写项目名称,控制项目位置,创建: 在源文件中添加新项: 填写文件名称,修改后缀: 编写一个简单的hello word编译看看windows环境支持如何: