题意:

  有n<6部电梯,给出每部电梯可以停的一些特定的楼层,要求从0层到达第k层出来,每次换乘需要60秒,每部电梯经过每层所耗时不同,具体按 层数*电梯速度 来算。问经过多少秒到达k层(k可以为0)?

思路:

  dijkstra再加一些特殊的处理就行了。首先要考虑,如何建图:

(1)每层作为一个点。但是特定路径可以有多种权,比如从2->5可以坐1号电梯10s,但是坐2号只需要5s,所以有重边。

(2)k=0时,不耗时间。

(3)有多种路径可达同一楼层且权值相同,那么从本楼层到另一楼层有多种选择,有时可以不换电梯,有时需要换。比如到达5楼的有2条路径,权都是5,但是是两部不同的电梯1和2,此时有其他电梯可以从5到7楼,其中有一部仍是电梯1,如果坐电梯1则不需要换乘时间,坐其他电梯就要了。所以要记录到某个点权值相等的电梯号。

 #include <bits/stdc++.h>
#define LL long long
#define pii pair<int,int>
#define INF 0x7f7f7f7f
using namespace std;
const int N=;
int take[];
char s[];
vector<int> lift[], vect[];
int cost[N], vis[N];
struct node
{
int from, to, lift, cost;
node(){};
node(int from,int to,int lift,int cost):from(from),to(to),lift(lift),cost(cost){};
}edge[];
int edge_cnt; void add_node(int from,int to,int lift,int cost)
{
edge[edge_cnt]=node(from,to,lift,cost);
vect[from].push_back(edge_cnt++);
} void build_graph(int n) //重新建图
{
for(int i=; i<n; i++)
{
for(int j=; j<lift[i].size(); j++)
{
for(int t=j+; t<lift[i].size(); t++)
{
int a=lift[i][j];
int b=lift[i][t];
add_node(a,b,i,(b-a)*take[i]);
add_node(b,a,i,(b-a)*take[i]);
}
}
}
} int dijkstra(int s,int e)
{
vector<int> flo[];
memset(cost,0x7f,sizeof(cost));
memset(vis,,sizeof(vis) ); priority_queue<pii,vector<pii>,greater<pii> > que;
que.push( make_pair(,s));
cost[s]=;
while(!que.empty())
{
int x=que.top().second;que.pop();
if(vis[x]) continue; vis[x]=;
for(int i=; i<vect[x].size(); i++)
{
node e=edge[vect[x][i]];
int ext=; for(int j=; j<flo[e.from].size(); j++) //如果有一个匹配,就不用额外时间
if( flo[e.from][j]==e.lift ) ext=; if(cost[e.to]>=cost[e.from]+ext+e.cost )
{
if( cost[e.to]>cost[e.from]+ext+e.cost ) flo[e.to].clear();
flo[e.to].push_back(e.lift); cost[e.to]= cost[e.from] +ext +e.cost;
que.push( make_pair(cost[e.to], e.to) );
}
}
}
return cost[e];
} int main()
{
freopen("input.txt", "r", stdin);
int n, k;
while(~scanf("%d%d",&n,&k))
{
for(int i=; i<n; i++) lift[i].clear();
for(int i=; i<; i++) vect[i].clear();
memset(s,,sizeof(s)); for(int i=; i<n; i++) scanf("%d",&take[i]);
getchar();
for(int i=; i<n; i++)
{
lift[i].clear();
gets(s);
int p=;
while(s[p]!='\0')
{
if(s[p]==' ') p++;
int tmp=;
while(s[p]!=' ' &&s[p]!='\0' ) tmp=tmp*+(s[p++]-'');
lift[i].push_back(tmp);
}
}
build_graph(n);
int ans=dijkstra(,k);
if(!k) puts("");
else if(ans==INF) puts("IMPOSSIBLE");
else printf("%d\n", ans- ) ;
}
return ;
}

AC代码

UVA 10801 Lift Hopping 电梯换乘(最短路,变形)的更多相关文章

  1. UVa 10801 - Lift Hopping(dijkstra最短路)

    根据题意,以每一层楼为顶点,每个电梯可以到达的两层楼之间的秒数为每一条边的权值,以此构建一个无向图.然后利用dijkstra求出最短的时间,注意每次换乘电梯需要等待60s(因为同一个电梯上的楼层是相互 ...

  2. uva 10801 - Lift Hopping(最短路Dijkstra)

    /* 题目大意: 就是一幢大厦中有0-99的楼层, 然后有1-5个电梯!每个电梯有一定的上升或下降速度和楼层的停止的位置! 问从第0层楼到第k层最少经过多长时间到达! 思路:明显的Dijkstra , ...

  3. UVA 10801 Lift Hopping 最短路

    2种方式直接代码就可以了.注意首次不需要60S的转换 #include <map> #include <set> #include <list> #include ...

  4. UVa 10801 Lift Hopping (Dijkstra)

    题意:有一栋100层的大楼(标号为0~99),里面有n个电梯(不超过5个),以及要到达的层数(aid),然后是每个电梯走一层所需的时间, 再n行就是对应每个电梯可以到达的层数,数量不定.然后每装换一次 ...

  5. UVa 10801 Lift Hopping【floyd 】

    题意:给出n个电梯,每个电梯的运行时间,每个电梯只能在相应的楼层停靠,而且没有楼梯,再给出想去的楼层,问从0层能否到达想去的楼层,求到达的最短时间 建图还是没有建出来--- 因为n<100,可以 ...

  6. UVa 10801 Lift Hopping / floyd

    乘电梯 求到目标层的最短时间 有n个电梯 换一个电梯乘需要额外60秒 所以建图时每个电梯自己能到的层数先把时间算好 这是不需要60秒的 然后做floyd时 如果松弛 肯定是要换电梯 所以要加60秒 # ...

  7. UVA 10801 Lift Hopping

    算是一道需要动脑筋的最短路问题了,关键在于建图部分,对于n个电梯中每一个都要经过cnt个楼层,a[0],a[1],a[2],a[3],a[4],......a[cnt-1],那么对于任意两个楼层a[j ...

  8. UVA 10801 多线程最短路

    题意:一栋摩天大楼从0层到K层,有N部电梯,每个电梯都有自己的运行速度,此外,对于某个电梯来说,并不是每一层都会停,允许在某一层进行电梯换乘,每次换乘固定消耗60秒,最终求从0层去K层的最短时间,如果 ...

  9. UVA 11248 - Frequency Hopping(网络流量)

    UVA 11248 - Frequency Hopping 题目链接 题意:给定一个网络,如今须要从1到N运输流量C,问是否可能,假设可能输出可能,假设不可能,再问能否通过扩大一条边的容量使得可能,假 ...

随机推荐

  1. CentOS7 安装 PostGIS方法(适合国内网络

    安装Postgresql 9.4 yum install http://yum.postgresql.org/9.4/redhat/rhel-6-x86_64/pgdg-redhat94-9.4-1. ...

  2. ComboTree使用

      1.参考资料 1.http://www.jeasyui.com/documentation/combotree.php 2.http://blog.csdn.net/woshichunchun/a ...

  3. [转载]DateTime TryParse

    今天被Architect问住了,说你光用一个TryParse就判断人家是不是时间日期型的,是不完整的.所以我花点时间看了下TryParse的用法. MSDN:http://msdn.microsoft ...

  4. 《head first java 》读书笔记(三)

    Updated 2014/04/03 --P518 Thread需要任务,任务是实现过Runnable的实例.Runnalbe这个接口只有一个方法.run()会是新线程所执行的第一项方法.要把Runn ...

  5. Openstack Grizzily 单节点测试机安装( All In One CentOS/RHEL)

    Openstack Grizzily版本已经相当完善,根据官方文档安装基本不存在什么问题,但是想快速测试了解Openstack功能的用户非常多,devstack的安 装需要check最新的代码,时常碰 ...

  6. What is Object Oriented Design? (OOD)

    Object Oriented Design is the concept that forces programmers to plan out their code in order to hav ...

  7. POJ 3045

    Cow Acrobats Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 2302   Accepted: 912 Descr ...

  8. java基础知识回顾之java Thread类学习(十)--线程的状态以及转化使用的方法介绍

       线程的概述:         线程是程序的多个执行路径,执行调度的单位,依托于进程存在.线程不仅可以共享进程的内存,而且还拥有一个属于自己的内存空间,这段内存空间叫做线程栈,是建立线程的时候由系 ...

  9. Servlet 各种path路径比较

    假定你的web application 名称为news,你在浏览器中输入请求路径: http://localhost:8080/news/main/list.jsp 则执行下面向行代码后打印出如下结果 ...

  10. Java Socket文件上传

    客户端: import java.io.FileInputStream; import java.net.Socket; /** * Created by 290248126 on 14-5-11. ...