http://poj.org/problem?id=1661

一般化处理,把一开始的落地和大地都视作平台,设计平台类的属性。dp的时候显然是从上往下dp的,而且要小心Jimmy不能够穿过平台,也就是从平台左侧掉下或者从右侧掉下都只能有一次。

#include<cmath>
#include<algorithm>
#include<iostream>
#include<cstdio>
using namespace std;
#define ll long long int N,X,Y,MAX; struct P{
int lx,rx,y;
int lt,rt;
int t;
bool operator<(P that){
return y>that.y;
}
}p[]; void update(int id){
int leftblock=;
int rightblock=;
for(int i=id+;i<N+;i++){
int dh=p[id].y-p[i].y;
if(dh>MAX)
return;
if(leftblock==&&p[i].lx<=p[id].lx&&p[i].rx>=p[id].lx){
p[i].lt=min(p[i].lt,p[id].lt+dh+abs(p[id].lx-p[i].lx));
p[i].rt=min(p[i].rt,p[id].lt+dh+abs(p[id].lx-p[i].rx));
p[i].t=min(p[i].t,p[id].lt+dh);
leftblock=;
} if(rightblock==&&p[i].lx<=p[id].rx&&p[i].rx>=p[id].rx){
p[i].lt=min(p[i].lt,p[id].rt+dh+abs(p[id].rx-p[i].lx));
p[i].rt=min(p[i].rt,p[id].rt+dh+abs(p[id].rx-p[i].rx));
p[i].t=min(p[i].t,p[id].rt+dh);
rightblock=;
}
//cout<<"i="<<i<<" "<<p[i].lt<<" "<<p[i].rt<<" "<<p[i].t<<endl; }
} int main(){
int t;
scanf("%d",&t);
while(t--){
scanf("%d%d%d%d",&N,&X,&Y,&MAX);
p[].lx=p[].rx=X;
p[].y=Y;
p[].lt=p[].rt=p[].t=;
for(int i=;i<N+;i++){
scanf("%d%d%d",&p[i].lx,&p[i].rx,&p[i].y);
p[i].lt=p[i].rt=p[i].t=0x3f3f3f3f;
}
p[N+].lx=-;
p[N+].rx=;
p[N+].y=;
p[N+].lt=p[N+].rt=p[N+].t=0x3f3f3f3f;
sort(p,p+N+);
for(int i=;i<N+;i++){
update(i);
//cout<<p[i].lt<<" "<<p[i].rt<<" "<<p[i].t<<endl;
} printf("%d\n",p[N+].t);
}
}

2月24日就整理到这里了

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

  1. POJ 1661 Help Jimmy【DP】

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

  2. POJ 1661 Help Jimmy LIS DP

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

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

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

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

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

  5. POJ 1661 Help Jimmy(递推DP)

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

  6. poj 1157 LITTLE SHOP_简单dp

    题意:给你n种花,m个盆,花盆是有顺序的,每种花只能插一个花盘i,下一种花的只能插i<j的花盘,现在给出价值,求最大价值 简单dp #include <iostream> #incl ...

  7. POJ 1661 Help Jimmy(二维DP)

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

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

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

  9. POJ 1661 Help Jimmy DP

    思路:Jimmy 跳到一块板上后,可以有两种选择,向左走或向右走.走到左端和走到右端所需的时间,容易算出. n如果我们能知道,以左端为起点到达地面的最短时间,和以右端为起点到达地面的最短时间,那么向左 ...

随机推荐

  1. Solidworks如何绘制标准螺纹线

    1 绘制螺旋线,螺距为0.5mm,圈数为15,起始角度为0°.   2                

  2. poj 3169 Layout(差分约束)

    Layout Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6549   Accepted: 3168 Descriptio ...

  3. Indri和Terrier搜索引擎的使用

    介绍 Indri和Terrier都是开源的搜索引擎,当中Indri作为Lemur项目的一个重要部分,具有强大的查询接口,易建索引,可扩展,高效率等长处.能够在SourceForge Lemur Pro ...

  4. docker (2)---存储、网络(利用docker容器上线静态网站)

    一.docker底层依赖的核心技术 1.命名空间 (Namespaces) 2.控制组 (Control Groups) 3.联合文件系统 (Union File System) 4.Linux 虚拟 ...

  5. 微软开源 Try .NET - 创建交互式.NET文档

    微软近日开源了一个新平台--Try .NET,该平台可以让开发者在线上编写并运行 .NET 代码.微软介绍,Try .NET 是一个可嵌入的代码运行器,不仅可以直接在线上对自己或者他人的代码进行编辑. ...

  6. scrollTo(String text) and scrollToExact(String text) method of Android Driver not working

    Using the scrollTo(String text) and scrollToExact(String text) method of Android Driver. However the ...

  7. configuration类详解

    hadoop中,组件配置是由Hadoop的Configuration的一个实例实现.(在源码包的org.apache.hadoop.conf中可以找到)先上个类图:这只是部分的,Configuraat ...

  8. numpy计算

    import numpy as np import cv2 from PIL import Image #lenna.jpg # Create a black image #img=np.zeros( ...

  9. 20170228 Z_po_send_email

    FUNCTION zmm_po_send_email. function zmm_po_send_email. *"------------------------------------- ...

  10. UIBarButtonSystemItem 各种款式