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. 9 个让 JavaScript 调试更简单的 Console 命令

    一.显示信息的命令 <!DOCTYPE html> <html> <head> <title>常用console命令</title> < ...

  2. linux添加ssh用户

    正好有朋友问,就转过来分享下. 转自:http://blog.sina.com.cn/s/blog_6fc583e70100n6rm.html 测试环境:CentOS 5.5 1.添加用户,首先用ad ...

  3. Xposed知识

    最近闹得沸沸扬扬的MIUI抄袭Xposed不署名事件,为此在这里普及一下相关的Xposed的知识. 相关资源 source code: https://github.com/rovo89 online ...

  4. typedef和typename关键字

    .类型说明typedef 类型说明的格式为: typedef 类型 定义名; 类型说明只定义了一个数据类型的新名字而不是定义一种新的数据类型.定义名表示这个类型的新名字. 例如: 用下面语句定义整型数 ...

  5. IPVS

    http://kb.linuxvirtualserver.org/wiki/IPVS_FULLNAT_and_SYNPROXY

  6. [Effective C++ --008]别让异常逃离析构函数

    这章非常容易理解:因为C++并不禁止析构函数吐出异常,只是不鼓励这样做而已. 一.原因 假设我们有10个装着鸡蛋的容器,而且现在我们还想着把它在析构函数打烂. class Egg { public : ...

  7. 文件和目录之chmod和fchmod函数

    本篇博文内容摘自<UNIX环境高级编程>(第二版),仅作个人学习记录所用.关于本书可参考:http://www.apuebook.com/. 这两个函数使我们可以更改现有文件的访问权限: ...

  8. PAT 1014

    1014. Waiting in Line (30) Suppose a bank has N windows open for service. There is a yellow line in ...

  9. c/c++编译原理

    转载自:http://blog.csdn.net/chengocean/article/details/6250779C源程序-->预编译处理(.c)-->编译.优化程序(.s..asm) ...

  10. Unix网络编程(1)——socket一窥

    套接口地址结构 IPv4的套接口地址结构为: struct sockaddr_in { uint8_t sin_len; sa_family_t sin_family; struct in_addr ...