#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<cstring>
using namespace std;
const int N=;
const int M=;
const int INF=0x3f3f3f;
struct Time
{
int x1,x2,h;
}a[N];
int dp[N+][]; // 0:表示第i的木板左边到底部的最短时间
// 1: 表示第i的木板右边到底部的最短时间
int n,x,y,max_h;
int cmp(Time c,Time b) //排序函数
{
return c.h > b.h; //从大到小排列
}
void left(int i)//左
{
//如果平台i下面有平台,且两者相距不超过MAX
int k = i+;
while( k<n+ && a[i].h-a[k].h<=max_h ) //n+1处是地面
{
//确保平台k在平台i的左下方,且小鼠可以跳到上面
if(a[i].x1>=a[k].x1&&a[i].x1<= a[k].x2)
{
//从i的左端跳到地面的时间
//i先跳到k的时间+
//min(从k左端跳到地面的时间+从i的左端到k的左端的时间,从k的右端跳到地面的时间+从i左端到k的右端)
dp[i][]=a[i].h-a[k].h+min(dp[k][]+a[i].x1-a[k].x1,dp[k][]+a[k].x2-a[i].x1);
return;
}
k++;
}
//因为第二个条件出的循环即:不能到达下一平台
if(a[i].h-a[k].h>max_h)
dp[i][]=INF;
//因为它下面没木板,直接落地
else
dp[i][]=a[i].h;
}
void right(int i)//右
{
//如果平台i下面有平台,且两者相距不超过MAX
int k=i+;
while(k<n+ && a[i].h-a[k].h<=max_h)
{
//确保平台k在平台i的右下方,且小鼠可以跳到上面
if(a[i].x2<=a[k].x2 && a[i].x2 >= a[k].x1)
{
dp[i][]=a[i].h-a[k].h+min(dp[k][] + a[i].x2-a[k].x1 , dp[k][] + a[k].x2-a[i].x2);
return;
}
k++;
}
//不能到达下一平台
if(a[i].h-a[k].h > max_h)
dp[i][]=INF;
//因为它下面没木板,直接落地
else
dp[i][]=a[i].h;
}
int main()
{
int t,i;
cin>>t;
while(t--)
{
//木板个数、老鼠的初始坐标、最大跳跃高度
cin>>n>>x>>y>>max_h;
//地面也当做一块木板
a[].x1=-;
a[].x2=;
a[].h=;
//老鼠初始位置也当做一块木板
a[].x1=x;
a[].x2=x;
a[].h=y;
//输入数据
for(i=;i<=n+;i++)
cin>>a[i].x1>>a[i].x2>>a[i].h;
//高度从大到小
sort(a,a+n+,cmp);
//初始化
memset(dp,,sizeof(dp));
//n+1是地面
//所以从n开始
for(i=n; i>= ;i--)
{
//进行左:去bfs
left(i);
//进行右:去bfs
right(i);
}
cout<<min(dp[][],dp[][])<<endl;
}
return ;
}

Help Jimmy POJ - 1661 dp的更多相关文章

  1. E - Help Jimmy POJ - 1661 dp

    E - Help Jimmy POJ - 1661 这个题目本身不是很难,但是可以更加优化这个写法. 开始是n*n #include <cstdio> #include <cstri ...

  2. Help Jimmy POJ - 1661 数字三角DP

    题意:中文 https://vjudge.net/problem/POJ-1661 题解:设两个dp数组,dpl[i]存 从第i块板左边到地上所花的最短时间,dpr[i]存右边的. 将所有板按高度排序 ...

  3. POJ 1661 DP

    Help Jimmy Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 11071   Accepted: 3607 Descr ...

  4. POJ 1661 Help Jimmy(递推DP)

    思路: 1. 每个板子有左右两端, dp[i][0], dp[i][1] 分别记录左右端到地面的时间 2. 从下到上递推计算, 上一层的板子必然会落到下面的某一层板子上, 或者地面上 总结: 1. 计 ...

  5. POJ 1661 Help Jimmy(C)动态规划

    没刷过 POJ,这题是论坛有人问的,我才看看. 我发现 POJ 注册很奇怪,账号总是登不上去,弄的我还注册两个.Emmm 首次体验很差,还好我不在 POJ 刷题. 题目链接:POJ 1661 Help ...

  6. POJ 1661 Help Jimmy(二维DP)

    题目链接:http://poj.org/problem?id=1661 题目大意: 如图包括多个长度和高度各不相同的平台.地面是最低的平台,高度为零,长度无限. Jimmy老鼠在时刻0从高于所有平台的 ...

  7. POJ - 1661 - Help Jimmy - 简单dp

    http://poj.org/problem?id=1661 一般化处理,把一开始的落地和大地都视作平台,设计平台类的属性.dp的时候显然是从上往下dp的,而且要小心Jimmy不能够穿过平台,也就是从 ...

  8. POJ 1661 Help Jimmy【DP】

    基础DP,过程想明白了其实也不复杂,从上面的推下面的比倒着推要简单很多.调试了半个多小时..简单dp依然不能快速AC..SAD.. 题目链接: http://poj.org/problem?id=16 ...

  9. POJ 1661 Help Jimmy LIS DP

    http://poj.org/problem?id=1661 对板按高度排序后. dp[i][0]表示现在站在第i块板上,向左跑了,的状态,记录下时间和其他信息. O(n^2)LIS: 唯一的麻烦就是 ...

随机推荐

  1. Vue开发中的常用技巧(持续更新)

    1. 监听子组件的生命周期例如有父组件Parent和子组件Child,如果父组件监听到子组件挂载mounted就做一些逻辑处理,常规写法可能如下: // Parent.vue <Child @m ...

  2. SQL Server解惑——对象命名的唯一性小结

    关于SQL Server数据库中的对象命名的唯一性问题.例如表.索引.约束等数据库对象,有时候DBA在做数据库维护时,经常要创建对象或重命名对象,此时就会遇到一个问题,对象命名的唯一性问题.虽然是一个 ...

  3. 准备工作-Visual Studio 安装

    说明 网上很多安装教程,等到自己有时间的时候再写一篇自己安装的详细步骤 安装参考(网络) https://blog.csdn.net/qq_33485434/article/details/78454 ...

  4. clr via c# 定制特性

    1,特性的应用范围:特性可应用于程序集,模块,类型,字段,方法,方法参数,方法返回值,属性,参数,泛型参数 2,利用前缀告诉编译器表明意图---下面的倾斜是必须的表明了我们的目标元素: [assemb ...

  5. MongoDB 添加用户名和密码

    MongoDB 添加用户名和密码 我用的是 mongodb3.6,如果没有的话先安装. sudo apt install mongodb 终端输入mongo,首先添加管理用户, show dbs // ...

  6. JavaScript中条件分支语句和循环语句的使用,用简洁的代码实现强大功能

    if()  else if()   else() alert() 弹出警告框 prompt() 输入框,确定:返回输入信息:取消:返回null <!DOCTYPE html> <ht ...

  7. SpringBoot 教程之 profile 的应用

    目录   区分环境的配置  区分环境的代码  激活 profile  示例源码  参考资料 一个应用为了在不同的环境下工作,常常会有不同的配置,代码逻辑处理.Spring Boot 对此提供了简便的支 ...

  8. Vue图片验证码-自定义组件高级版

    最近项目中要用到图片验证码,网上一查有很多,基本都是千篇一律的4位纯数字验证码.首先得感谢那位一代目兄台提供的模板,由于不能满足需求,所以对其进行了改造升级. 经改造的图片验证码能满足一下情形使用:① ...

  9. STL-list 链表

    #include <iostream> #include <list> using namespace std; int main() { // list可以在头部和尾部插入和 ...

  10. Pikachu-URL重定向

    不安全的url跳转 不安全的url跳转问题可能发生在一切执行了url地址跳转的地方.如果后端采用了前端传进来的(可能是用户传参,或者之前预埋在前端页面的url地址)参数作为了跳转的目的地,而又没有做判 ...