POJ 1661 暴力dp
题意略。
思路:
很有意思的一个题,我采用的是主动更新未知点的方式,也即刷表法来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的更多相关文章
- POJ 1661 Help Jimmy(递推DP)
思路: 1. 每个板子有左右两端, dp[i][0], dp[i][1] 分别记录左右端到地面的时间 2. 从下到上递推计算, 上一层的板子必然会落到下面的某一层板子上, 或者地面上 总结: 1. 计 ...
- E - Help Jimmy POJ - 1661 dp
E - Help Jimmy POJ - 1661 这个题目本身不是很难,但是可以更加优化这个写法. 开始是n*n #include <cstdio> #include <cstri ...
- POJ 2182/暴力/BIT/线段树
POJ 2182 暴力 /* 题意: 一个带有权值[1,n]的序列,给出每个数的前面比该数小的数的个数,当然比一个数前面比第一个数小的个数是0,省略不写,求真正的序列.(拗口) 首先想到的是从前到后暴 ...
- Luogu P1436 棋盘分割 暴力DP
我的天,,,,,n=8,k<=15,,,这怕不是暴力DP+高维数组.... 开一个五维数组f[k][i][j][p][q]表示从(i,j)到(p,q)中分成k个矩形最小的平方和. 然后初始化时用 ...
- Fire (poj 2152 树形dp)
Fire (poj 2152 树形dp) 给定一棵n个结点的树(1<n<=1000).现在要选择某些点,使得整棵树都被覆盖到.当选择第i个点的时候,可以覆盖和它距离在d[i]之内的结点,同 ...
- 暴力/DP Codeforces Beta Round #22 (Div. 2 Only) B. Bargaining Table
题目传送门 /* 题意:求最大矩形(全0)的面积 暴力/dp:每对一个0查看它左下的最大矩形面积,更新ans 注意:是字符串,没用空格,好事多磨,WA了多少次才发现:( 详细解释:http://www ...
- 【2019.8.8 慈溪模拟赛 T1】开箱(chest)(暴力DP水过)
转化题意 这题目乍一看十分玄学,完全不可做. 但实际上,假设我们在原序列从小到大排序之后,选择开的宝箱编号是\(p_{1\sim Z}\),则最终答案就是: \[\sum_{i=1}^Za_{p_i} ...
- 【2019.8.12 慈溪模拟赛 T1】钥匙(key)(暴力DP)
暴力\(DP\) 这题做法很多,有\(O(n^2)\)的,有\(O(n^2logn)\)的,还有徐教练的\(O(nlogn)\)的,甚至还有\(bzt\)的二分+线段树优化建图的费用流. 我懒了点,反 ...
- POJ 1661 Help Jimmy(C)动态规划
没刷过 POJ,这题是论坛有人问的,我才看看. 我发现 POJ 注册很奇怪,账号总是登不上去,弄的我还注册两个.Emmm 首次体验很差,还好我不在 POJ 刷题. 题目链接:POJ 1661 Help ...
随机推荐
- git 必看,各种撤销操作
场景概念说明 首先说明一个概念, git是一个分布式的版本控制工具,分布式即 git 管理的项目是有多个大致平等的仓库的.通过一个例子来说明这个东西. 举一个最简单的使用场景: 你在github 建立 ...
- java的System.currentTimeMillis()和System.nanoTime
纳秒 ns(nanosecond):纳秒, 时间单位.一秒的10亿分之一,即等于10的负9次方秒.常用作 内存读写速度的单位,其前面数字越小则表示速度越快. 1纳秒=1000 皮秒 1纳秒 = ...
- rem的基准字体大小的设置
1.移动端 UI 给的设计稿通常是640px.720px.750px的宽度,但是我们要做适配,兼容不同的终端,rem布局是比较常用的一种方式,比较关键的是确定根节点的字体大小. 这里以640px为例, ...
- ES2019 / ES10有什么新功能?
ECMAScript(简称ES)是ECMA International在ECMA-262和ISO / IEC 16262中标准化的脚本语言规范.它是为了标准化JavaScript语言而创建的,以便从浏 ...
- Java性能权威指南读书笔记--之二
新生代填满时,垃圾收集器会暂停所有的应用线程,回收新生代空间.这种操作被称为Minor GC. 老年代被填满时,垃圾收集器会暂停所有应用线程,对其进行回收,接着对堆空间进行整理.这个过程被称为Full ...
- 基于Spring框架应用的权限控制系统的研究和实现
摘 要: Spring框架是一个优秀的多层J2EE系统框架,Spring本身没有提供对系统的安全性支持.Acegi是基于Spring IOC 和 AOP机制实现的一个安全框架.本文探讨了Acegi安全 ...
- javascript数组去重 js数组去重
数组去重的方法 一.利用ES6 Set去重(ES6中最常用) function unique (arr) { return Array.from(new Set(arr)) } var arr = [ ...
- PHP版本的区别与用法详解
在我们安装PHP模块时,有时需要注意PHP编译的版本,下面讲解下PHP中VC6.VC9.TS.NTS版本的区别与用法详解,介绍php的两种执行方式. 1. VC6与VC9的区别:VC6版本是使用Vis ...
- dns自动配置shell脚本
代码: #!/bin/bash #获取url echo "url:" read url #获取ip echo "ip:" read ip #向/etc/name ...
- 从源码看Flask框架配置管理
1 引言 Flask作为Python语言web开发的三大顶梁柱框架之一,对于配置的管理当然必不可少.一个应用从开发到测试到最后的产品发布,往往都需要多种不同的配置,例如是否开启调试模式.使用哪个数据库 ...