题意略。

思路:

很有意思的一个题,我采用的是主动更新未知点的方式,也即刷表法来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. 使用c++开发跨平台的程序

    使用c++开发跨平台的程序 背景 在开发过程中,使用c++作为开发语言,通常被认为是痛苦的,啰嗦的,超长开发时间的.最近几年有各种各样的语言被广泛使用,相对比来说c++不是那么出彩.c++虽然年龄大, ...

  2. Visual Studio 调试(系列文章)

    调试是软件开发过程中非常重要的一个部分,它具挑战性,但是也有一定的方法和技巧. Visual Studio 调试程序有助于你观察程序的运行时行为并发现问题. 该调试器可用于所有 Visual Stud ...

  3. 数据库---T-SQL语句:查询语句(二)

    >查询: 一.查询所有数据: select * from Info    ---查询所有数据(行) select Name from Info  ---查询特定列(Name列) select N ...

  4. 解读equals()和hashCode()

    前面部分摘自:https://blog.csdn.net/javazejian/article/details/51348320 一:Object中equals方法的实现原理 public boole ...

  5. linux初学者-sshd服务

     linux初学者-sshd服务   在linux系统操作中,经常需要连接其他的主机,连接其他主机的服务是openssh-server,它的功能是让远程主机可以通过网络访问sshd服务,开始一个安全s ...

  6. 解决win10下MySQL 8.0登录Access denied for user 'root'@'localhost' (using password: YES)的问题

        近些时间在开始学MySQL,安装挺顺利的,按照网上现成的教程就能安装成功.     但是,在输入 mysql -uroot -p     再输入密码时,遇到了这个情况 Access denie ...

  7. js实现字符串转JSON格式

    在浏览器前端实现字符串转JSON格式,有多种方法,总结如下: 方法1. js函数,eval() 语法: var obj = eval ("(" + txt + ")&qu ...

  8. Java基础之十五 泛型

    第十五章 泛型 一般的类和方法,只能使用具体的类型:要么是基本类型,要么是自定义类型.如果要编写可以应用于多种类型的代码,这种刻板的限制对代码的束缚就会很大. 在面对对象编程语言中,多态算是一种泛化机 ...

  9. Pyinstaller 打包工具的使用!!!

    打包成一个文件夹: pyinstaller xxx.py 打包成单个文件: pyinstaller -F xxx.py 打包成不显示终端的单个文件: pyinstaller -F -w xxx.py ...

  10. Oracle DBLink跨数据库访问SQL server数据同步 踩坑实录

    项目需求:这里暂且叫A公司吧,A公司有一套人事管理软件,需要与我们公司的软件做人员信息同步,A公司用的是SQL server数据库,我们公司用的Oracle,接口都不会开发(一万句"fuck ...