COCI 2003 LIFTOVI 电梯 SPFA

LIFTOVI

Solitaire has N elevators. Each elevator are connecting exactly two floors and it does not stop on the
floors between that two floors. The speed of all the elevators are the same, 5 seconds to pass one
floor.
On the beginning, each elevator is in its lower position and they are starting cruising to the upper floor.
After some elevator come to its upper position, it immediatly starts to go back to its lower position,
and so on...
Mirko is on the first (the lowest) floor and he wants as quick as possible come to the top of the
solitaire. He can change elevators only on the floors that are common to both elevators, and if the
other elevator is in that moment on that floor, that change does not take any time.
Write a program that will calculate minimal time in which Mirko can get to the top of the solitaire.
Input data
In the first line of the input file there are two integers K and N, separated with space, number of floors
in solitaire and number of elevators, 2 ≤ K ≤ 1000, 1 ≤ N ≤ 50000.
In each of the next N lines there are description of one elevator, two integers A and B, separated with
space, 1 ≤ A < B ≤ K, means that elevator is travelling between floors A and B.
There are no two different elevators that travels between same floors.
Note: input data will guarantee that solution will always exists.
Output data
In the only line of output file write minimal time (in seconds) from the text above.
Examples


liftovi.in
10 4
1 5
5 10
5 7
7 10
liftovi.out
45


liftovi.in
10 3
1 5
3 5
3 10
liftovi.out
105


liftovi.in
20 5
1 7
7 20
4 7
4 10
10 20
liftovi.out
150

分析

首先我们要明确这道题目的基本方法,因为这道题目求最短的时间(我们将其理解为最短路程的问题),最短路程一定是从起点一层层向前推,首先找到的符合条件的答案是最有答案。那么我们就确定下来,这道题用基于广搜的SPFA。

对于模板SPFA,这道题最大的一个改变就是路程的量变成了时间,所以我们关键在于如何分析写出时间的公式。对于当前状态(已用时间,所在楼层),我们要将其从队列中弹出,然后枚举与当前楼层相连的所有电梯,分成两种情况。接下来电梯下行,和接下来电梯上行两种情况。对于上行,我们有公式:

dis = f[a[x][1]]+(y/2+y-f[a[x][1]]%y)%y+y/2;

也可以理解为:

SUCC = PRE + (y/2+y-PRE%y)%y + y/2;

相对的,电梯下行的公式就是:

dis = f[a[x][0]]+(y-f[a[x][0]]%y)%y+y/2;

这样一来,程序就是模板SPFA了。

程序

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 int n, m, i, j, t, k, s, f[1005], a[50005][2];
 4 vector<int> vec[1005];
 5 bool inq[1005];
 6 void SPFA()
 7 {
 8     memset(f,0x3F3F3F3F,sizeof(f));
 9     f[1]=0;
10     queue<int> Q;
11     Q.push(1);
12     while (!Q.empty())
13     {
14         int t = Q.front();
15         Q.pop();
16         inq[t]=0;
17         for (int i=0;i<vec[t].size();++i)
18         {
19             int x = vec[t][i], y = (a[x][1]-a[x][0])*2*5;
20             if (t == a[x][0])
21             {
22                 int dis = f[a[x][0]]+(y-f[a[x][0]]%y)%y+y/2;
23                 if (f[a[x][1]]>dis)
24                 {
25                     f[a[x][1]]=dis;
26                     if (!inq[a[x][1]])
27                     {
28                         inq[a[x][1]]=1;
29                         Q.push(a[x][1]);
30                     }
31                 }
32             }
33             else
34             {
35                 int dis=f[a[x][1]]+(y/2+y-f[a[x][1]]%y)%y+y/2;
36                 if (f[a[x][0]]>dis)
37                 {
38                     f[a[x][0]]=dis;
39                     if (!inq[a[x][0]])
40                     {
41                         inq[a[x][0]]=1;
42                         Q.push(a[x][0]);
43                     }
44                 }
45             }
46         }
47     }
48 }
49 
50 int main()
51 {
52     freopen("liftovi.in","r",stdin);
53     freopen("liftovi.out","w",stdout);
54     scanf("%d%d",&n,&m);
55     for (i=1;i<=m;++i)
56     {
57         scanf("%d%d",&a[i][0],&a[i][1]);
58         vec[a[i][0]].push_back(i);
59         vec[a[i][1]].push_back(i);
60     }
61     SPFA();
62     printf("%d\n",f[n]);
63     return 0;
64 }

 

转载于:https://www.cnblogs.com/OIerPrime/p/9320612.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip
综合小区管理系统管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、车位管理、车位分配管理、出入管理、字典管理、房屋管理、物业费缴纳管理、公告管理、物业人员投诉管理、我的私信管理、物业人员管理、用户管理、管理员管理。用户的功能包括管理部门以及部门岗位信息,管理招聘信息,培训信息,薪资信息等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 综合小区管理系统管理系统可以提高综合小区管理系统信息管理问题的解决效率,优化综合小区管理系统信息处理流程,保证综合小区管理系统信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理综合小区管理系统信息,包括出入管理,报修管理,报修管理,物业费缴纳等,可以管理操作员。 出入管理界面,管理员在出入管理界面中可以对界面中显示,可以对招聘信息的招聘状态进行查看,可以添加新的招聘信息等。报修管理界面,管理员在报修管理界面中查看奖罚种类信息,奖罚描述信息,新增奖惩信息等。车位管理界面,管理员在车位管理界面中新增。公告管理界面,管理员在公告管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值