题意略。

思路:

很有意思的一个题,我采用的是主动更新未知点的方式,也即刷表法来dp。

我们可以把整个路径划分成横向移动和纵向移动,题目一开始就给出了Jimmy的高度,这就是纵向移动的距离。

我们dp的目标是每个线段端点的横向移动最小值。

有一个小trick,就是有可能Jimmy开始就可以落在地上,没有必要或者说在下落过程中不会有间隔来阻拦。

代码附上:

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn = ;
const int INF = 0x3f3f3f3f;
const int F = 0x3f; struct segment{
int l,r,h;
segment(int l = ,int r = ,int h = ){
this->l = l,this->r = r,this->h = h;
}
}; segment store[maxn];
int dp[maxn<<],N,x,h,MAX,t;
bool covered[maxn<<]; bool cmp(const segment& s0,const segment& s1){
return s0.h > s1.h;
}
bool inSegment(int x,segment s){
return s.l <= x && x <= s.r;
} int main(){
scanf("%d",&t);
while(t--){
scanf("%d%d%d%d",&N,&x,&h,&MAX);
for(int i = ;i < N;++i) scanf("%d%d%d",&store[i].l,&store[i].r,&store[i].h);
memset(dp,F,sizeof(dp));
memset(covered,false,sizeof(covered));
sort(store,store + N,cmp);
int ans = h,lft,rht,lp,rp,nlft,nrht,nlp,nrp;
for(int i = ;i < N;++i){
lft = i<<,rht = lft + ;
if(inSegment(x,store[i])){
dp[lft] = x - store[i].l,dp[rht] = store[i].r - x;
break;
}
}
for(int i = ;i < N;++i){
lft = i<<,rht = lft + ;
lp = store[i].l,rp = store[i].r;
int cnt0 = ,cnt1 = ;
if(dp[lft] == INF) continue;
for(int j = i + ;store[i].h - store[j].h <= MAX && j < N && cnt0 + cnt1 < ;++j){
if(store[i].h == store[j].h) continue;
nlft = j<<,nrht = nlft + ;
nlp = store[j].l,nrp = store[j].r;
if(!cnt0 && inSegment(lp,store[j])){
dp[nlft] = min(dp[nlft],dp[lft] + lp - nlp);
dp[nrht] = min(dp[nrht],dp[lft] + nrp - lp);
cnt0 = ;
}
if(!cnt1 && inSegment(rp,store[j])){
dp[nlft] = min(dp[nlft],dp[rht] + rp - nlp);
dp[nrht] = min(dp[nrht],dp[rht] + nrp - rp);
cnt1 = ;
}
}
} for(int i = ;i < N;++i){
if(store[i].h > MAX) continue;
for(int j = i + ;j < N;++j){
if(inSegment(store[i].l,store[j])) covered[i<<] = true;
if(inSegment(store[i].r,store[j])) covered[i<< | ] = true;
}
} int minn = INF;
for(int i = N - ;i >= && store[i].h <= MAX;--i){
lft = i<<,rht = lft + ;
if(!covered[lft]) minn = min(minn,dp[lft]);
if(!covered[rht]) minn = min(minn,dp[rht]);
}
if(minn == INF) minn = ;
ans += minn;
printf("%d\n",ans);
}
return ;
} /* 1
3 4 4 5
3 5 3
1 7 2
2 6 1
*/

POJ 1661 暴力dp的更多相关文章

  1. POJ 1661 Help Jimmy(递推DP)

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

  2. E - Help Jimmy POJ - 1661 dp

    E - Help Jimmy POJ - 1661 这个题目本身不是很难,但是可以更加优化这个写法. 开始是n*n #include <cstdio> #include <cstri ...

  3. POJ 2182/暴力/BIT/线段树

    POJ 2182 暴力 /* 题意: 一个带有权值[1,n]的序列,给出每个数的前面比该数小的数的个数,当然比一个数前面比第一个数小的个数是0,省略不写,求真正的序列.(拗口) 首先想到的是从前到后暴 ...

  4. Luogu P1436 棋盘分割 暴力DP

    我的天,,,,,n=8,k<=15,,,这怕不是暴力DP+高维数组.... 开一个五维数组f[k][i][j][p][q]表示从(i,j)到(p,q)中分成k个矩形最小的平方和. 然后初始化时用 ...

  5. Fire (poj 2152 树形dp)

    Fire (poj 2152 树形dp) 给定一棵n个结点的树(1<n<=1000).现在要选择某些点,使得整棵树都被覆盖到.当选择第i个点的时候,可以覆盖和它距离在d[i]之内的结点,同 ...

  6. 暴力/DP Codeforces Beta Round #22 (Div. 2 Only) B. Bargaining Table

    题目传送门 /* 题意:求最大矩形(全0)的面积 暴力/dp:每对一个0查看它左下的最大矩形面积,更新ans 注意:是字符串,没用空格,好事多磨,WA了多少次才发现:( 详细解释:http://www ...

  7. 【2019.8.8 慈溪模拟赛 T1】开箱(chest)(暴力DP水过)

    转化题意 这题目乍一看十分玄学,完全不可做. 但实际上,假设我们在原序列从小到大排序之后,选择开的宝箱编号是\(p_{1\sim Z}\),则最终答案就是: \[\sum_{i=1}^Za_{p_i} ...

  8. 【2019.8.12 慈溪模拟赛 T1】钥匙(key)(暴力DP)

    暴力\(DP\) 这题做法很多,有\(O(n^2)\)的,有\(O(n^2logn)\)的,还有徐教练的\(O(nlogn)\)的,甚至还有\(bzt\)的二分+线段树优化建图的费用流. 我懒了点,反 ...

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

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

随机推荐

  1. markdown表情

    Emoji表情 将对应emoji表情的符号码复制后输入你的markdown文本即可显示emoji表情. 如:blush:,显示为

  2. Kotlin学习快速入门(3)——类 继承 接口

    类 参考链接 类定义格式 使用class关键字定义,格式如下: class T{ //属性 //构造函数 //函数 //内部类 } Java Bean类 java bean类 //java bean类 ...

  3. JQuery制作简易的考试答题管理系统

    网页效果: 代码部分: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> & ...

  4. 【iOS】No suitable application records found

    昨天提交 Apple 审核时遇到这个问题,如图: 原来是还没在 iTunes Connect 创建 APP ... 一时着急大意了…… 后来想想还真是脑子一时没反应过来……

  5. Another option to bootup evidence files

    When it comes to booting up evidence files acquired from target disk, you got two options. One is VF ...

  6. 数据结构之稀疏矩阵C++版

    //只是简单的演示一下,这个实际运用视乎不怎么多,所以java版不再实现 /* 希疏矩阵应用于对数据的压缩,仅仅保留不为0的数据 稀疏矩阵的转置,可以由多种方式,下面演示的稍显简单,时间复杂度略高O( ...

  7. C#使用代理IP发送请求

    https://www.cnblogs.com/benbenfishfish/p/5830149.html   获取可代理的IP https://www.cnblogs.com/ShalenChe/p ...

  8. leetcode 29 两数相除

    问题描述 给定两个整数,被除数 dividend 和除数 divisor.将两数相除,要求不使用乘法.除法和 mod 运算符. 返回被除数 dividend 除以除数 divisor 得到的商. 示例 ...

  9. Zookeeeper应用实践(四)

    zk的应用还是非常广泛的. 1. 分布式锁 单机环境下的锁还是很容易去实现的,但是在分布式环境下一切都变得不是那么简单.zk实现分布式锁的原理还简单,因为在分布式环境中的zk节点的变化会被每一台机器w ...

  10. Opengl_入门学习分享和记录_02_渲染管线(一)顶点着色器&片段着色器

    写在前面的废话:今天俺又来了哈哈,真的好棒棒! 今天的内容:之前我们大概描述了,我们自己定义的顶点坐标是如何被加载到GPU之中,并且介绍了顶点缓冲对象VBO用于管理这一块内存.今天开始详细分析它的具体 ...