博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ-1925 Spiderman 动态规划
阅读量:6943 次
发布时间:2019-06-27

本文共 1268 字,大约阅读时间需要 4 分钟。

详见代码:

#include 
#include
#include
#include
#include
#include
#define INF 0x3f3f3f3f#define MAXN 1000005using namespace std;/*题意:给定N个柱子,现在要在这N个柱子之间摇摆,直至到达最右端的那一个柱子,问最少要 摇摆多少次. 摇摆的时机是在开始的时候或者是从某一点摇摆到某个对称的点时,保 证所有的柱子的高度不低于出发点的高度. 解法:设dp[i]表示在x坐标为i时候所需要的最少摇摆次数.这里有一个准备工作就是计算出 每根柱子的一个可接受区间.计算的结果是对于第k个柱子范围是[ ceil(Xk-sqrt(2*Yk*Y1-Y1*Y1)), Xk-1 ] 然后对每根柱子所能够接受的区间内进行动态规划 dp[i] = max(dp[k] + 1), 其中要求k在i号柱子接受的区间内 */int N, dp[MAXN];struct Node { int x, y, ac;}e[5005];int DP() { // 从左至右遍历柱子才能够保证每个柱子递推过来的点都已经计算过 int ret = INF; memset(dp, 0x3f, sizeof (dp)); dp[e[1].x] = 0; // 出发点为有效点 for (int i = 2; i <= N; ++i) { int a = e[i].ac, b = e[i].x; // [a, b]就是i号柱子的接受的区间 for (int j = a; j < b; ++j) { int p = 2*e[i].x-j; if (p < e[N].x) { dp[p] = min(dp[p], dp[j]+1); } else { ret = min(ret, dp[j]+1); // 已经跳到最右边了 } } } return ret == INF ? -1 : ret;}int main() { int T; scanf("%d", &T); while (T--) { scanf("%d", &N); for (int i = 1; i <= N; ++i) { scanf("%d %d", &e[i].x, &e[i].y); e[i].ac = max(0, (int)ceil(e[i].x-sqrt(2.*e[i].y*e[1].y-1.*e[1].y*e[1].y))); } printf("%d\n", DP()); } return 0; }

 

转载于:https://www.cnblogs.com/Lyush/archive/2013/01/14/2860454.html

你可能感兴趣的文章
EF实体框架之CodeFirst四
查看>>
[Tex学习]WinEdit 常用软件快捷键
查看>>
二维码在短信业务应用的初步构思
查看>>
分布式服务器集群架构方案思考
查看>>
Graphviz使用简介(中文乱码的问题)
查看>>
Log4J使用
查看>>
【反编译系列】三、反编译神器(jadx)
查看>>
Xamarin Essentials教程安全存储SecureStorage
查看>>
[Maid] Write Tasks in Markdown with Maid
查看>>
tf.reducemean()到底是什么意思?
查看>>
像调试java一样来调试Redis lua
查看>>
What is Socket.IO?
查看>>
使用select实现非阻塞socket | dbafree首页
查看>>
The bug when Use Tomat in Eclipse
查看>>
wine 源
查看>>
抽象工厂资料汇总
查看>>
javascript 杂谈之哪种写法你更喜欢?
查看>>
nil localizedTitle in SKProduct
查看>>
EGORefreshTableHeaderView学习
查看>>
POJ3364
查看>>