/*96655 's source code for M
Memory: 8604 KB Time: 63 MS
Language: G++ Result: Accepted
*/
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<cstring>
#include<cstring>
#include<vector>
#include<queue>
#include<stack>
using namespace std;
short x[],y[],h[];
short xx[],hh[],xcnt,hcnt,d,ww,f;
int dp[][];
bool cmp(int a,int b)
{
return a>b;
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int n,bb,cc,m;
scanf("%d%d%d%d",&n,&bb,&cc,&m);
xcnt=hcnt=;
for(int i=; i<=n; ++i)
{
scanf("%d%d%d",&x[i],&y[i],&h[i]);
xx[xcnt++]=x[i];
xx[xcnt++]=y[i];
hh[hcnt++]=h[i];
}
xx[xcnt++]=bb;
hh[hcnt++]=;
sort(xx,xx+xcnt);
sort(hh,hh+hcnt,cmp);
d=;
for(int i=; i<xcnt; i++)
if(xx[i]!=xx[i-])xx[d++]=xx[i];
xcnt=d,d=;
for(int i=; i<hcnt; i++)
if(hh[i]!=hh[i-])hh[d++]=hh[i];
hcnt=d;
vector<int>a[hcnt+];
memset(dp,-,sizeof(dp));
int ans=0x3f3f3f3f;
for(int i=; i<xcnt; i++)
dp[hcnt-][i]=ans;
for(int i=; i<=n; i++)
{
int id;
for(int j=; j<hcnt; j++)
if(h[i]==hh[j])
{
id=j;
break;
}
int s=lower_bound(xx,xx+xcnt,x[i])-xx;
int t=lower_bound(xx,xx+xcnt,y[i])-xx;
a[id].push_back(s);
a[id].push_back(t);
for(int j=s; j<=t; ++j)
dp[id][j]=ans;
}
f=lower_bound(xx,xx+xcnt,bb)-xx;
for(int i=; i<hcnt; i++)
{
if(dp[i][f]!=-)
{
dp[i][f]=cc-hh[i];
ww=i;
break;
}
}
for(int i=ww; i<hcnt-; ++i)
{
for(int j=; j<xcnt; j++)
{
if(dp[i][j]<ans&&dp[i][j]!=-)
{
int s,t;
for(int k=;k<a[i].size();k+=)
{
if(a[i][k-]<=j&&a[i][k]>=j)
{
s=a[i][k-];
t=a[i][k];
break;
}
}
int l=xx[j]-xx[s],r=xx[t]-xx[j];
dp[i][s]=min(dp[i][s],dp[i][j]+l);
dp[i][t]=min(dp[i][t],dp[i][j]+r); }
}
for(int j=; j<a[i].size(); ++j)
{
int p=a[i][j];
if(dp[i][p]!=-&&dp[i][p]<ans)
{
for(int k=i+; k<hcnt&&hh[i]-hh[k]<=m; k++)
if(dp[k][p]!=-)
{
dp[k][p]=min(dp[k][p],dp[i][p]+hh[i]-hh[k]);
break;
}
}
}
}
for(int i=; i<xcnt; i++)
ans=min(ans,dp[hcnt-][i]);
printf("%d\n",ans);
}
return ;
}

POJ 1661 Help Jimmy的更多相关文章

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

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

  2. POJ 1661 Help Jimmy(递推DP)

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

  3. POJ 1661 Help Jimmy -- 动态规划

    题目地址:http://poj.org/problem?id=1661 Description "Help Jimmy" 是在下图所示的场景上完成的游戏. 场景中包括多个长度和高度 ...

  4. OpenJudge/Poj 1661 帮助 Jimmy

    1.链接地址: bailian.openjudge.cn/practice/1661 http://poj.org/problem?id=1661 2.题目: 总Time Limit: 1000ms ...

  5. POJ 1661 Help Jimmy(二维DP)

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

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

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

  7. POJ 1661 Help Jimmy【DP】

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

  8. POJ 1661 Help Jimmy LIS DP

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

  9. POJ 1661 Help Jimmy(DP,注意边界)

    Help Jimmy Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 9399   Accepted: 3025 Descri ...

  10. POJ 1661 Help Jimmy(DP/最短路)

    Help Jimmy Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 14980 Accepted: 4993 Descripti ...

随机推荐

  1. 使用Pod集成Bugtags填坑记

    最近某朋友的朋友的创业公司新出了一个工具叫Bugtags,说是可以让APP测试变得so easy,于是动手来做1.1.0的版本集成,先把WEB首页贴在下面,感兴趣的同学可以去look一下:https: ...

  2. GodSon Easyui 结合Pluplaod插件的文件分割上传

    自己整理了一个文件分割上传的实例,提供研究学习使用. 在线查看效果       下载该资源pluplaod文件分割上传Demo.zip 简介: 首先,进入页面会看到下面的效果: 点击一个按钮,出现如图 ...

  3. scrum敏捷开发

    团队PM:袁佩佩 scrum敏捷开发计划制定: 确定项目实施具体阶段目标 确定项目相关任务分解 确定每日站立会议进行计划 确定项目计划总结日程 确定风险解决方案

  4. OpenSessionInViewFilter 的配置及替代方案(转)

    鸣谢:http://justsee.iteye.com/blog/1174999,http://blog.csdn.net/sunsea08/article/details/4545186 Sprin ...

  5. WEB开发人员必知的20+HTML5技巧(转)

    互联网科技发展的速度真可谓惊人的快,一个稍不留神,你就可能无法跟上它的步伐. HTML5的变化和更新也压倒不少人,这篇文章将向大家介绍一些最基本也非常必要的 HTML技巧. 1. 新的文档类型(Doc ...

  6. Windows2003/2008/2008 R2下易语言点支持库配置就退出的问题

    问题: 请问一个问题,我的电脑上win2003系统的,安装了易语言后,一点支持库配置就会自动退出.这是为什么啊? 解决方法如下: 删除 lib下的wmp.npk,重新打开易语言就可以了.

  7. JUnit 4 使用 Java 5 中的注解(annotation)

    JUnit 4 使用 Java 5 中的注解(annotation),以下是JUnit 4 常用的几个 annotation 介绍@Before:初始化方法@After:释放资源@Test:测试方法, ...

  8. ADO.net--杂七杂八(一)

    private void BtnConnectDataBase_Click(object sender, RoutedEventArgs e) { string connectionString = ...

  9. linux distribution是什么?

    linux distribution,即Linux发行版,有很多种类,包括Fedora,Ubuntu,Debian,Red Hat,SuSE等,其内核都是差不多的,只是界面设计和功能上各有千秋.

  10. mysql查看数据库命令

    mysql查看数据库命令 打开的数据库的命令 mysql> use mysql Database changed 查看数据库的命令 mysql> show databases; 查看数据表 ...