洛谷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. VS 安装resharper 后 无法进行UnitTest

    Vs安装 Resharper后,无法进行单元测试,发现报错提示信息如下: ignored test-case is missing. rebuild the project and try again ...

  2. NetCore2.2开发环境搭建和2008R2部署环境搭建

    开发环境: 开发工具:VS2017 系统:Win10 64位 Skd下载地址: https://dotnet.microsoft.com/download 3个都下载下载,安装dotnet-sdk-2 ...

  3. 树莓派4B安装Raspbian系统及配置

    2019/11/11, 树莓派4B, Raspbian Buster 摘要:给树莓派4B安装系统及基础配置 树莓派实验室参考文档 准备工具 树莓派4B硬件 SD卡格式化工具 SD Formatter ...

  4. Ubuntu系统下搭建docke

    linux内核版本依赖 kernel version >= 3.8 可以使用如下命令查看 uname -a | awk '{split($3, arr, "-"); prin ...

  5. [Windows] - DNS防污染工具Pcap_DNSProxy

    最近试过非常多的DNS防污染工具(包括:dnsforwarder.dnsforwarder.dnscrypt-proxy.SimpleDNSCrypt等),感觉这个Pcap_DNSProxy简单.快捷 ...

  6. xshell连接本地linux虚拟机速度很慢的解决办法

    今天发现用xshell连接centos太慢,网上查询后发现是因为ssh的服务端在连接时会自动检测dns环境是否一致导致的,修改为不检测即可. 修改文件位置:vi /etc/ssh/sshd_confi ...

  7. elementUI一次请求上传多个文件

    elementui <el-upload                       class="upload-demo"                       ac ...

  8. js对数组array的常见操作小结

    1.创建数组?两种方式 var arr = new Array("1","2","4"); var arr1 = ["1" ...

  9. VMware虚拟机文件夹中各文件作用详解

    虚拟机的文件管理由VMware Workstation来执行 一个虚拟机一般以一系列文件的形式储存在宿主机中,这些文件一般在由workstation为虚拟机所创建的那个目录中 这里列出了这些关键文件及 ...

  10. 记Html的初次接触

    第一次接触Html是在昨天的培训班体验课上,这一次课我明白了许多. 1.程序语言比我想象中还要多(原来除了C与Java还有这么多) 2.程序员毕业后掌握7种语言是很正常的事(难怪程序员会秃顶) 3.H ...