1.链接地址:

bailian.openjudge.cn/practice/1661

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

2.题目:

总Time Limit:
1000ms
Memory Limit:
65536kB
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恰好落在某个平台的边缘,被视为落在平台上。所有的平台均不重叠或相连。测试数据保证问题一定有解。

Output
对输入的每组测试数据,输出一个整数,Jimmy到底地面时可能的最早时间。
Sample Input
1
3 8 17 20
0 10 8
0 10 13
4 14 3
Sample Output
23
Source
POJ Monthly--2004.05.15 CEOI 2000

3.思路:

动态规划题目

注意Jimmy老鼠直接落到0高度的情况

4.代码:

 #include <iostream>
#include <cstdio>
#include <cstdlib> using namespace std; struct FLAT
{
int x[];
int h;
}; int cmp(const void* a,const void* b)
{
FLAT flat1 = *((FLAT *)a);
FLAT flat2 = *((FLAT *)b); return flat1.h - flat2.h;
} int main()
{
//freopen("C://input.txt","r",stdin); int t;
cin >> t; // 0 <= t <= 20 int i,j,k; int n,x,y,max;
while(t--)
{
//1 <= N <= 1000,-20000 <= X, X1[i], X2[i] <= 20000,0 < H[i] < Y <= 20000(i = 1..N)
cin >> n >> x >> y >> max; FLAT *arr_flat = new FLAT[n]; for(i = ; i < n; ++i) cin >> arr_flat[i].x[] >> arr_flat[i].x[] >> arr_flat[i].h;
qsort(arr_flat,n,sizeof(FLAT),cmp); //for(i = 0; i < n; ++i) cout << arr_flat[i].x[0] << " " << arr_flat[i].x[1] << " " << arr_flat[i].h << endl; int m;
for(m = n - ; m >= ; --m)
{
if(y - arr_flat[m].h <= max && x >= arr_flat[m].x[] && arr_flat[m].x[] >= x) break;
}
if(m < )
{
cout << y << endl;
continue;
} //dp
int **dp = new int*[m + ];
for(i = ; i <= m; ++i) dp[i] = new int[]; dp[][] = arr_flat[].h;
dp[][] = arr_flat[].h; for(i = ; i <= m; ++i)
{
for(j = ; j < ; ++j)
{
int flag = ;
for(k = i - ; k >= ; --k)
{
if(arr_flat[i].h - arr_flat[k].h > max) break;
else
{
if(arr_flat[k].x[] <= arr_flat[i].x[j] && arr_flat[k].x[] >= arr_flat[i].x[j])
{
flag = ;
break;
}
}
}
if(flag == )
{
if(arr_flat[i].h < max) dp[i][j] = arr_flat[i].h;
else dp[i][j] = -;
}
else
{
if(dp[k][] == - && dp[k][] == -) dp[i][j] = -;
else if(dp[k][] == -) dp[i][j] = dp[k][] + (arr_flat[i].h - arr_flat[k].h) + (arr_flat[k].x[] - arr_flat[i].x[j]);
else if(dp[k][] == -) dp[i][j] = dp[k][] + (arr_flat[i].h - arr_flat[k].h) + (arr_flat[i].x[j] - arr_flat[k].x[]);
else
{
int temp1 = dp[k][] + (arr_flat[i].h - arr_flat[k].h) + (arr_flat[i].x[j] - arr_flat[k].x[]);
int temp2 = dp[k][] + (arr_flat[i].h - arr_flat[k].h) + (arr_flat[k].x[] - arr_flat[i].x[j]);
dp[i][j] = temp1 < temp2 ? temp1 : temp2;
}
}
}
} if(dp[m][] == -) cout << dp[m][] + (arr_flat[m].x[] - x) + (y - arr_flat[m].h) << endl;
else if(dp[m][] == -) cout << dp[m][] + (x - arr_flat[m].x[]) + (y - arr_flat[m].h) << endl;
else
{
int temp1 = dp[m][] + (arr_flat[m].x[] - x) + (y - arr_flat[m].h);
int temp2 = dp[m][] + (x - arr_flat[m].x[]) + (y - arr_flat[m].h);
cout << (temp1 < temp2 ? temp1 : temp2) << endl;
} for(i = ; i <= m; ++i) delete [] dp[i];
delete [] dp; delete [] arr_flat;
} return ;
}

OpenJudge/Poj 1661 帮助 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. POJ 1661 Help Jimmy(二维DP)

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

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

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

  6. POJ 1661 Help Jimmy【DP】

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

  7. POJ 1661 Help Jimmy LIS DP

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

  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/最短路)

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

随机推荐

  1. 解决SenTestingKit/SenTestingKit.h: No such file or directory

    在一个iOS项目中引入了单元测试,感觉项目间的依赖关系有些乱,就建了一个新的Project,再把原来的.h和.m加进去,编译时竟然出现“SenTestingKit/SenTestingKit.h: N ...

  2. Android真机抓屏- Android Screen Monitor

    一般运行Android应用程序有两种方式一种是设置Android虚拟设备模拟器,通过Android  Virtual Manger进行管理,一种是插入USB数据线直接真机上进行调试,但是如果电脑配置比 ...

  3. ASP终极防下载(转)

    自从搞ASP+ACCESS没少为避免数据库下载而伤过神,网上的奇淫技巧更是数不胜数,本文就是同大家共同探讨各路前辈的留下的秘笈并指中其中的优劣,最后为大家提供一种最佳的解决方案. 一.开篇 自从搞AS ...

  4. File类的基本操作之读出所有目录路径

    package org.mark.file; import java.io.File; /** * File类的基本操作之读出所有文件夹路径 * 假设给定一个文件夹,要求将此文件夹中的所有文件都列出来 ...

  5. javascript调试 console

    Console命令详解,让调试js代码变得更简单   Firebug是网页开发的利器,能够极大地提升工作效率. 但是,它不太容易上手.我曾经翻译过一篇<Firebug入门指南>,介绍了一些 ...

  6. ajax检查用户名

    Ajax实现的效果 究竟Ajax能实现什么功能呢?今天下午学习了一下Ajax,现在跟大家分享一下我的学习心得.Ajax是什么?工作机制又是什么?可能不大准确,只是我个人看了视频学习后的一点点看法. A ...

  7. springMVC项目在jboss7中配置应用自己的log4j--转载

    原文地址:http://www.xuebuyuan.com/1954635.html Jboss7默认采用容器自己的log4j module,应用自己配置的log4j不起作用,需要应用做一些设置: 以 ...

  8. vsftpd给root设置访问权限

    1:Linux下安装vsftpd之后,默认的配置是匿名用户可以登录,匿名帐户有两个:用户名:anonymous密码:空 用户名:ftp密码:ftp 2:如果要用匿名进行上传删除等操作需要配置其它参数. ...

  9. Mac下Sublime Text Vim模式 方向键无法长按

    在Mac终端输入(不是sublime text里的console),分别对应ST2.ST3: defaults ApplePressAndHoldEnabled -bool false default ...

  10. Django request 常用属性

    一.request属性 path  获取url全路径(出去域名外) 用法: request.path GET 用户所有的get内容以字典的形式存储 例:{'name':'alan'} 用法: data ...