B - Help Jimmy
B - Help Jimmy
Problem Description
"Help Jimmy" 是在下图所示的场景上完成的游戏:
场景中包括多个长度和高度各不相同的平台。地面是最低的平台,高度为零,长度无限。
Jimmy老鼠在时刻0从高于所有平台的某处开始下落,它的下落速度始终为1米/秒。当Jimmy落到某个平台上时,游戏者选择让它向左还是向右跑,它跑动的速度也是1米/秒。当Jimmy跑到平台的边缘时,开始继续下落。Jimmy每次下落的高度不能超过MAX米,不然就会摔死,游戏也会结束。
设计一个程序,计算Jimmy到地面时可能的最早时间。
Input
第一行是测试数据的组数t(0 <= t <= 20)。每组测试数据的第一行是四个整数N,X,Y,MAX,用空格分隔。N是平台的数目(不包括地面),X和Y是Jimmy开始下落的位置的横竖坐标,MAX是一次下落的最大高度。接下来的N行每行描述一个平台,包括三个整数,X1[i],X2[i]和H[i]。H[i]表示平台的高度,X1[i]和X2[i]表示平台左右端点的横坐标。1<= N <= 1000,-20000 <= X, X1[i], X2[i] <= 20000,0 < H[i] < Y <= 20000(i = 1..N)。所有坐标的单位都是米。
Jimmy 的大小和平台的厚度均忽略不计。如果Jimmy 恰好落在某个平台的边缘,被视为落在平台上。所有的平台均不重叠或相连。测试数据保Jimmy一定能安全到达地面。
Output
对输入的每组测试数据,输出一个整数,Jimmy到地面时可能的最早时间。
Sample Input
1
3 8 17 20
0 10 8
0 10 13
4 14 3Sample Output
23
#include<cstdio>
#include<algorithm>
using namespace std; const int inf = 0x3f3f3f3f; // 表示无限大 大约是1e9多一点 struct Node { // 结构体数组用于记录每个位置的状态
int l, r, h; // 当前位置的左右端点、高度
int t, lt, rt; // 到达当前位置的时间、到达当前位置左右端点的时间
bool operator < (const Node& b) const{ // 重载运算符用于排序,按照高度降序排序
return h > b.h;
}
}a[]; int main()
{
int T, n, x, y, max;
scanf("%d", &T);
while(T--) { // T组测试样例
scanf("%d%d%d%d", &n, &x, &y, &max); a[].l = a[].r = x;
a[].t = a[].lt = a[].rt = ;
a[].h = y;
// 给a[0]赋值,代表初始的位置,左右边界都是x,左右时间都是0,高度为y for(int i=; i<=n; i++)
scanf("%d%d%d", &a[i].l, &a[i].r, &a[i].h);
// 输入每个平台的左右端点和高度,下标[1, n] a[n+].l = -;
a[n+].r = ;
a[n+].h = ;
// 给a[n+1]赋值,左右边界都到题目要求的最大值,表示地面 sort(a, a+n+);
// 按照高度降序,给n+2个元素排序 for(int i=; i<n+; i++){ // 按照高度降序,计算到达平台的时间
a[i].t = a[i].lt = a[i].rt = inf; // 到达平台的时间一开始置为无限大
for(int j=i-; j>=; j--){ // 必须是倒序遍历,因为里面有break
if(a[j].h - a[i].h > max) break; // 超过高度则跳出,因为降序
if(a[j].l >= a[i].l && a[j].l <= a[i].r){ // a[j]从左侧落下可以落在i上
int down_time = a[j].h - a[i].h; // 下落时间
int movel_time = a[j].l - a[i].l; // 下落后,移动到左端点的时间
int mover_time = a[i].r - a[j].l; // 下落后,移动到右端点的时间
// 更新取min
a[i].t = min(a[i].t, a[j].lt + down_time);
a[i].lt = min(a[i].lt, a[j].lt + down_time + movel_time);
a[i].rt = min(a[i].rt, a[j].lt + down_time + mover_time);
a[j].l = -; // 因为从从a[j]下落后一定只能落在一个平台上,
// 为了避免重复,把a[j]的左端点置为最小值
} if(a[j].r >= a[i].l && a[j].r <= a[i].r){ // a[j]从右侧落下可以落在i上,
// 一定不能用else if
int down_time = a[j].h - a[i].h;
int movel_time = a[j].r - a[i].l;
int mover_time = a[i].r - a[j].r;
a[i].t = min(a[i].t, a[j].rt + down_time);
a[i].lt = min(a[i].lt, a[j].rt + down_time + movel_time);
a[i].rt = min(a[i].rt, a[j].rt + down_time + mover_time);
a[j].r = ;
}
}
}
printf("%d\n", a[n+].t); // 输出到达地面的时间即可
}
return ;
}
B - Help Jimmy的更多相关文章
- 递归,动态规划,找最短路径,Help Jimmy
题目链接:http://poj.org/problem?id=1661 解题报告: 1.老鼠每次来到一块木板上都只有两条路可以走,可以使用递归 #include <stdio.h> #in ...
- Why did Jimmy Wales invest in Quora? Is he afraid that it will take over Wikipedia?
QUESTION: Why did Jimmy Wales invest in Quora? Is he afraid that it will take over Wikipedia? Answer ...
- POJ 1661 Help Jimmy (dijkstra,最短路)
刚在百度搜索了一下这道题的题解, 因为看到有别人用动态规划做的,所以想参考一下. 结果顺带发现了有那么几个网站,上面的文章竟然和我这篇一模一样(除了一些明显的错别字外),我去,作者还是同一个人Admi ...
- POJ 1661 Help Jimmy -- 动态规划
题目地址:http://poj.org/problem?id=1661 Description "Help Jimmy" 是在下图所示的场景上完成的游戏. 场景中包括多个长度和高度 ...
- OpenJudge/Poj 1661 帮助 Jimmy
1.链接地址: bailian.openjudge.cn/practice/1661 http://poj.org/problem?id=1661 2.题目: 总Time Limit: 1000ms ...
- POJ 1661 Help Jimmy DP
思路:Jimmy 跳到一块板上后,可以有两种选择,向左走或向右走.走到左端和走到右端所需的时间,容易算出. n如果我们能知道,以左端为起点到达地面的最短时间,和以右端为起点到达地面的最短时间,那么向左 ...
- POJ1661 Help Jimmy
Help Jimmy Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 9863 Accepted: 3201 Descriptio ...
- Jimmy Choo_百度百科
Jimmy Choo_百度百科 Jimmy Choo
- POJ 1661 Help Jimmy(DP,注意边界)
Help Jimmy Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 9399 Accepted: 3025 Descri ...
- 新概念英语(1-101)A Card From Jimmy
Lesson 101 A card from Jimmy 吉米的明信片 Listen to the tape then answer this question. Does Grandmother s ...
随机推荐
- 配置伪静态(URL重写)
本篇借鉴了很多文章,这里做个记录. 有时我们的导航栏出现xx.aspx?id=x&name=xx 等等这样,会显得不好看,我们可以利用伪静态来美化我们的导航栏,伪静态的形式可以自己定义,本质还 ...
- 微信H5单页面滑动的时候如何避免出界,出现头部和底部的黑底?
ios系统微信浏览器.safari浏览器中h5页面上拉下滑导致悬浮层脱离窗口的解决方法 ios偶现下拉出现黑底时,界面第一次上拉时拉不动的解决方案: document.querySelector('# ...
- Ajax跨域请求以及乱码解决
Ajax跨域请求2种解决方法 1 ) 什么叫跨域请求,协议,域名,端口号,其中一样不同都称跨域; 第一种:使用script标签发送请求; //创建一个script标签; var v_element=d ...
- 深入理解java虚拟机学习笔记(二)垃圾回收策略
上篇文章介绍了JVM内存模型的相关知识,其实还有些内容可以更深入的介绍下,比如运行时常量池的动态插入,直接内存等,后期抽空再完善下上篇博客,今天来介绍下JVM中的一些垃圾回收策略. 一. ...
- Apache+Tomcat+jk windows环境下的集群部署
记一次在Windows服务器上搭建apatch+tomcat+jk的集群搭建过程,其中也遇到了很多问题,总结一下. 一.准备工作 1.apache-tomcat-7.0.88 2.Apche http ...
- python__高级 : 类的__getattribute__ 方法
在类 里面,其实并没有方法这个东西,所有的东西都保存在属性里面,所谓的调用方法其实是类里面的一个同名属性指向了一个函数(方法),返回的是函数的引用,再用 函数() 这种方式就可以调用它 在调 ...
- 完善压缩处理类(支持主流的图像类型(jpg、png、gif)
<?php /* * 图像压缩 */ class Thumb { //成员属性 private $file; //原图文件 private $thumb_path; //压缩文本件保存的地址 / ...
- eBay 表结构
erp_ebay_list 建表语句 CREATE TABLE `erp_ebay_list` ( `id` ) NOT NULL AUTO_INCREMENT COMMENT '自增主键', `na ...
- elasticsearch 5.x 系列之一 开始安装啦
以下是镇楼用的,各路退让,我要吹liubi 了 // // _oo0oo_ // o8888888o // 88" . "88 // (| -_- |) // 0\ = /0 // ...
- js for 循环中有异步函数时,回调函数总是最后一步的值。
原因:for循环执行时不会等待异步函数执行. 解决方法: 1.改为递归函数(暂时不会). 2.构建一个自执行函数传参(匿名函数) 参考::https://www.cnblogs.com/csuwuji ...