刚在百度搜索了一下这道题的题解, 因为看到有别人用动态规划做的,所以想参考一下。

结果顺带发现了有那么几个网站,上面的文章竟然和我这篇一模一样(除了一些明显的错别字外),我去,作者还是同一个人Admin,还是同一天发表。

我才是原作者!!!这里特别声明,请尊重版权,可以转载或者复制,但是请注明出处!!!

思路:我是转化成求最短路来解的。
     将每个平台看作两个点,即左端点和右端点,然后将符合条件的两点相连,边长即为两点之间的垂直距离和水平距离。
     将jimmy起始的地点看作顶点0,而地面看作顶点2*N+1,这样就是求0到2*N+1的单源最短路径,用dijkstra就可以搞定。

有几个要注意的地方:
  1.一开始做的时候,没仔细想,认为只要两个平台之间符合条件,就建立边的关系。
   忽略了一个平台下方最多只能有两个平台(即左端点下方一个,右端点下方一个)。也就是说一个点最多只能与一个点相连。
  2.jimmy有可能可以直接落到地上
  3.能与地面相连的点,必须保证它的下方没有阻隔的平台

#include <iostream>
#include <queue>
#include <stdio.h>
#include <algorithm>
#include <vector>
#include <string.h> using namespace std;
const int maxn=*+;
const int INF=0x3f3f3f3f;
int N,X,Y,MAX;
long long dis[maxn];
int vis[maxn];
int head[maxn];
int tot;
long long ans;
struct Line {
int l,r,h;
bool operator<(const Line tmp)const {
return h>tmp.h;
}
} line[maxn];
struct Node {
int u;
long long dis;
bool operator<(const Node tmp)const {
return dis>tmp.dis;
}
}; struct Edge {
int to,next;
int length;
} edge[maxn*maxn]; void add(int i,int j,int dis) {
edge[tot].next=head[i];
edge[tot].to=j;
edge[tot].length=dis;
head[i]=tot++;
}
void dijkstra(int s) {
for(int i=; i<maxn; i++) {
dis[i]=INF;
vis[i]=;
}
priority_queue<Node>q;
Node t;
t.u=s;
t.dis=;
dis[s]=;
q.push(t);
int v,u;
while(!q.empty()) {
t=q.top();
q.pop();
u=t.u;
vis[u]=; if(u==*N+){
ans=t.dis;
break;
} for(int k=head[u]; k!=-; k=edge[k].next) {
v=edge[k].to;
if(!vis[v] && dis[u]+edge[k].length<dis[v]) {
dis[v]=dis[u]+edge[k].length;
t.u=v;
t.dis=dis[v];
q.push(t);
} }
}
}
int main() {
int t;
scanf("%d",&t);
while(t--) {
memset(head,-,sizeof(head));
tot=;
scanf("%d%d%d%d",&N,&X,&Y,&MAX);
for(int i=; i<=N; i++) {
scanf("%d%d%d",&line[i].l,&line[i].r,&line[i].h);
}
sort(line+,line+N+);
int ldis,rdis;
for(int i=; i<=N; i++) {
//这里要考虑,不是所有在i平台下方符合的就可以建立边的关系
//而只能与它最近的平台才行。
//例如平台1,2,3,并且2、3都在1的下方,且满足条件。但1和3不能相连,因为中间隔着2,所以只能1和2相连
int cnt1=,cnt2=;
for(int j=i+; j<=N; j++) {
if(line[i].h-line[j].h>= && line[i].h-line[j].h<=MAX) {
if(line[j].l<=line[i].l && line[i].l<=line[j].r) {
cnt1++;
//左端下方第一个符合要求的
if(cnt1==) {
ldis=line[i].h-line[j].h+line[i].l-line[j].l;
add(i*-,j*-,ldis); rdis=line[i].h-line[j].h+line[j].r-line[i].l;
add(i*-,j*,rdis);
}
}
if(line[j].l<=line[i].r && line[i].r<=line[j].r) {
cnt2++;
//右端点下方第一个符合要求的
if(cnt2==) {
ldis=line[i].h-line[j].h+line[i].r-line[j].l;
add(i*,j*-,ldis); rdis=line[i].h-line[j].h+line[j].r-line[i].r;
add(i*,j*,rdis);
}
}
}
}
//若要与地面连接,则必须该平台下方没有其它阻隔的平台。
//如果该平台左端点下方没有其它平台阻隔,且满足条件,则与地面相连
if(!cnt1 && line[i].h<=MAX) {
add(i*-,*N+,line[i].h);
}
//如果该平台右端点下方没有其它平台阻隔,且满足条件,则与地面相连
if(!cnt2 && line[i].h<=MAX) {
add(i*,*N+,line[i].h);
}
}
//只能有一个平台与源点连接
int cnt=;
for(int j=; j<=N; j++) {
if(line[j].l<=X && X<=line[j].r && Y-line[j].h>= && Y-line[j].h<=MAX) {
cnt++;
//第一个符合要求的平台
if(cnt==) {
ldis=Y-line[j].h+X-line[j].l;
add(,j*-,ldis); rdis=Y-line[j].h+line[j].r-X;
add(,j*,rdis);
}
}
}
//没有平台在jimmy的下方,也就是jimmy可以直接到达地面。。。之前都忽略了额
if(cnt==) {
add(,*N+,Y);
}
dijkstra();
printf("%I64d\n",ans);
}
return ;
}

POJ 1661 Help Jimmy (dijkstra,最短路)的更多相关文章

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

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

  2. POJ 1661 Help Jimmy(递推DP)

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

  3. POJ 1661 Help Jimmy(DP/最短路)

    Help Jimmy Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 14980 Accepted: 4993 Descripti ...

  4. POJ 1661 Help Jimmy -- 动态规划

    题目地址:http://poj.org/problem?id=1661 Description "Help Jimmy" 是在下图所示的场景上完成的游戏. 场景中包括多个长度和高度 ...

  5. OpenJudge/Poj 1661 帮助 Jimmy

    1.链接地址: bailian.openjudge.cn/practice/1661 http://poj.org/problem?id=1661 2.题目: 总Time Limit: 1000ms ...

  6. POJ 1135 Domino Effect (Dijkstra 最短路)

    Domino Effect Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9335   Accepted: 2325 Des ...

  7. POJ 1661 Help Jimmy(二维DP)

    题目链接:http://poj.org/problem?id=1661 题目大意: 如图包括多个长度和高度各不相同的平台.地面是最低的平台,高度为零,长度无限. Jimmy老鼠在时刻0从高于所有平台的 ...

  8. poj 2253 Frogger (dijkstra最短路)

    题目链接:http://poj.org/problem?id=2253 Frogger Time Limit: 1000MS   Memory Limit: 65536K Total Submissi ...

  9. POJ - 1661 - Help Jimmy - 简单dp

    http://poj.org/problem?id=1661 一般化处理,把一开始的落地和大地都视作平台,设计平台类的属性.dp的时候显然是从上往下dp的,而且要小心Jimmy不能够穿过平台,也就是从 ...

随机推荐

  1. MIFARE系列8《D8M1.exe》

    软件名:D8M1.exe 更新时间:2014.06.28 操作系统:windowAll 外部设备:D8读卡器 D8M1可以对MIFARE块读写操作,支持1K,4K.检验KEY后返回SAK,QTAQ,U ...

  2. Percona-Xtrabackup 2.3.3 慢查询不再堵塞备份(一)

    在Percona-Xtrabackup 2.3.3[root@b28-19-17 bak]# rpm -q percona-xtrabackuppercona-xtrabackup-2.3.3-1.e ...

  3. hdu 4857 逃生

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=4857 逃生 Description 糟糕的事情发生啦,现在大家都忙着逃命.但是逃命的通道很窄,大家只能 ...

  4. net-snmp的安装

    安装环境是ubuntu 14. 方法1:apt-get install  net-snmp (非root用户需要sudo 提升权限) 方法2:自定义安装选择不同的版本去编译. 1:先去下载所需要的ta ...

  5. iOS学习之Object-C语言字符串和数值

    一.使用苹果帮助文档      1.帮助文档的作用:帮助开发者快速了解系统类的功能.           1)苹果每次iOS版本的升级,都会添加或者更新大量的API,并提供相应的参考文档.       ...

  6. MVC4.0 利用HandleErrorAttribute和log4net实现记录异常日志功能

    1.MVC4.0中HandleErrorAttribte已经帮我们处理了异常问题,当我们新建一个非空的MVC项目时候,在FilterConfig中会发现这样的代码 public class Filte ...

  7. 读TCP-IP详解卷1:协议(1)

    1.TCP传给IP的数据单元称作TCP报文段或简称为TCP段(TCP segment)IP传给网络接口层的数据单元称作IP数据报(IPdatagram).通过以太网传输的比特流称作帧(Frame).

  8. 在package.json中配置Script执行npm run tslint报错问题

    今天在学习tslint的时候,按照git clone下angular2-webpack-starter的代码执行npm run lint时,虽然代码进行了检测,但检测完成后npm始终报错, //pac ...

  9. [网络配置相关]——ifconfig命令、ip命令、route命令

    ifconfig命令 1. 查看已被激活的网卡的详细信息 # ifconfig eth0 Link encap:Ethernet HWaddr 00:30:67:F2:10:CF inet addr: ...

  10. [SSH服务]——SSH详解、常用的远程连接工具

    在总结ssh原理前,我先做了一个ssh过程的实验 首先我搭建了这样一个实验环境: (1) SSH Server:10.0.10.198 (2) SSH Client:10.0.10.158 在Serv ...