Help Jimmy POJ - 1661 dp
#include<iostream>
#include<stdio.h>
#include<algorithm>
#include<cstring>
using namespace std;
const int N=;
const int M=;
const int INF=0x3f3f3f;
struct Time
{
int x1,x2,h;
}a[N];
int dp[N+][]; // 0:表示第i的木板左边到底部的最短时间
// 1: 表示第i的木板右边到底部的最短时间
int n,x,y,max_h;
int cmp(Time c,Time b) //排序函数
{
return c.h > b.h; //从大到小排列
}
void left(int i)//左
{
//如果平台i下面有平台,且两者相距不超过MAX
int k = i+;
while( k<n+ && a[i].h-a[k].h<=max_h ) //n+1处是地面
{
//确保平台k在平台i的左下方,且小鼠可以跳到上面
if(a[i].x1>=a[k].x1&&a[i].x1<= a[k].x2)
{
//从i的左端跳到地面的时间
//i先跳到k的时间+
//min(从k左端跳到地面的时间+从i的左端到k的左端的时间,从k的右端跳到地面的时间+从i左端到k的右端)
dp[i][]=a[i].h-a[k].h+min(dp[k][]+a[i].x1-a[k].x1,dp[k][]+a[k].x2-a[i].x1);
return;
}
k++;
}
//因为第二个条件出的循环即:不能到达下一平台
if(a[i].h-a[k].h>max_h)
dp[i][]=INF;
//因为它下面没木板,直接落地
else
dp[i][]=a[i].h;
}
void right(int i)//右
{
//如果平台i下面有平台,且两者相距不超过MAX
int k=i+;
while(k<n+ && a[i].h-a[k].h<=max_h)
{
//确保平台k在平台i的右下方,且小鼠可以跳到上面
if(a[i].x2<=a[k].x2 && a[i].x2 >= a[k].x1)
{
dp[i][]=a[i].h-a[k].h+min(dp[k][] + a[i].x2-a[k].x1 , dp[k][] + a[k].x2-a[i].x2);
return;
}
k++;
}
//不能到达下一平台
if(a[i].h-a[k].h > max_h)
dp[i][]=INF;
//因为它下面没木板,直接落地
else
dp[i][]=a[i].h;
}
int main()
{
int t,i;
cin>>t;
while(t--)
{
//木板个数、老鼠的初始坐标、最大跳跃高度
cin>>n>>x>>y>>max_h;
//地面也当做一块木板
a[].x1=-;
a[].x2=;
a[].h=;
//老鼠初始位置也当做一块木板
a[].x1=x;
a[].x2=x;
a[].h=y;
//输入数据
for(i=;i<=n+;i++)
cin>>a[i].x1>>a[i].x2>>a[i].h;
//高度从大到小
sort(a,a+n+,cmp);
//初始化
memset(dp,,sizeof(dp));
//n+1是地面
//所以从n开始
for(i=n; i>= ;i--)
{
//进行左:去bfs
left(i);
//进行右:去bfs
right(i);
}
cout<<min(dp[][],dp[][])<<endl;
}
return ;
}
Help Jimmy POJ - 1661 dp的更多相关文章
- E - Help Jimmy POJ - 1661 dp
E - Help Jimmy POJ - 1661 这个题目本身不是很难,但是可以更加优化这个写法. 开始是n*n #include <cstdio> #include <cstri ...
- Help Jimmy POJ - 1661 数字三角DP
题意:中文 https://vjudge.net/problem/POJ-1661 题解:设两个dp数组,dpl[i]存 从第i块板左边到地上所花的最短时间,dpr[i]存右边的. 将所有板按高度排序 ...
- POJ 1661 DP
Help Jimmy Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 11071 Accepted: 3607 Descr ...
- POJ 1661 Help Jimmy(递推DP)
思路: 1. 每个板子有左右两端, dp[i][0], dp[i][1] 分别记录左右端到地面的时间 2. 从下到上递推计算, 上一层的板子必然会落到下面的某一层板子上, 或者地面上 总结: 1. 计 ...
- POJ 1661 Help Jimmy(C)动态规划
没刷过 POJ,这题是论坛有人问的,我才看看. 我发现 POJ 注册很奇怪,账号总是登不上去,弄的我还注册两个.Emmm 首次体验很差,还好我不在 POJ 刷题. 题目链接:POJ 1661 Help ...
- POJ 1661 Help Jimmy(二维DP)
题目链接:http://poj.org/problem?id=1661 题目大意: 如图包括多个长度和高度各不相同的平台.地面是最低的平台,高度为零,长度无限. Jimmy老鼠在时刻0从高于所有平台的 ...
- POJ - 1661 - Help Jimmy - 简单dp
http://poj.org/problem?id=1661 一般化处理,把一开始的落地和大地都视作平台,设计平台类的属性.dp的时候显然是从上往下dp的,而且要小心Jimmy不能够穿过平台,也就是从 ...
- POJ 1661 Help Jimmy【DP】
基础DP,过程想明白了其实也不复杂,从上面的推下面的比倒着推要简单很多.调试了半个多小时..简单dp依然不能快速AC..SAD.. 题目链接: http://poj.org/problem?id=16 ...
- POJ 1661 Help Jimmy LIS DP
http://poj.org/problem?id=1661 对板按高度排序后. dp[i][0]表示现在站在第i块板上,向左跑了,的状态,记录下时间和其他信息. O(n^2)LIS: 唯一的麻烦就是 ...
随机推荐
- webpack nodejs npm关系
nodejs是js后端运行平台,可以把它看成java体系中对应的jdk,是三个里面最基础的.npm是nodejs的包管理工具,可以把它看成maven中包依赖管理那部分.webpack是前端工程化打包工 ...
- vue路由--使用router.push进行路由跳转
手机赚钱怎么赚,给大家推荐一个手机赚钱APP汇总平台:手指乐(http://www.szhile.com/),辛苦搬砖之余用闲余时间动动手指,就可以日赚数百元 route-link是在html中静态定 ...
- [未完成]ECRound 80
Educational Codeforces Round 80 (Rated for Div. 2)A 大意:寻找x使得等式<=n,若满足情况输出YES否则NO 解法:纯数学题,先构造函数f(x ...
- Jmeter 连接Redis获取数据集
公司开展了新的业务活动,需要配合其他部门做压测,由于脚本中的手机号和用户的uid需要参数化而且每次均不能重复,最初的考虑使用csv的方式来获取数据,比较头疼的问题是集群节点需要维护测试数据,所以我将所 ...
- js—DOM详情
1,什么是DOM,有什么作用 Document Object Model 文档对象模型,是一个html和xml文档的编程接口,可以将文档(html页面)解析成dom树,然后通过提供的dom接口来改变文 ...
- Shiro -- (四) 数据库支持
主要就是JdbcRealm这个类 先看一下部分源码: 先建表:users(用户名 / 密码).user_roles(用户 / 角色).roles_permissions(角色 / 权限),并且往use ...
- 图解Java设计模式之设计模式面试题
图解Java设计模式之设计模式面试题 1.1 Java设计模式内容介绍 1.1.1 先看几个经典的面试题 1.1.2 设计模式的重要性 1.1 Java设计模式内容介绍 1.1.1 先看几个经典的面试 ...
- 疫情之下,使用FRP实现内网穿透,远程连接公司电脑进行办公
当前情况下,经常会有需要到公司电脑进行一些操作,比如连接内网OA,数据库或者提交文档.为了减少外出,将使用frp进行内网穿透的方法进行一个说明. 前提条件 1. 一台拥有公网 IP 的设备(如果没有, ...
- 解决“此Flash Player与您的地区不相容”
1.进入C:\Windows\System32\drivers\etc目录,将hosts文件拷贝到桌面,然后用文本编辑器,比如记事本,打开,在最后一行添加: 127.0.0.1 geo2.adobe. ...
- MySql学习-4.查询1
1.基本查询语法: select * from 表名: **注意** 1.select 后写列名,*代表是所有列: 2.列名可以用as起别名,其出现在结果集中: 3.查询多个列,之间用逗 ...