POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离)

Description

You have just moved from a quiet Waterloo neighbourhood to a big, noisy city. Instead of getting to ride your bike to school every day, you now get to walk and take the subway. Because you don't want to be late for class, you want to know how long it will take you to get to school.

You walk at a speed of 10 km/h. The subway travels at 40 km/h. Assume that you are lucky, and whenever you arrive at a subway station, a train is there that you can board immediately. You may get on and off the subway any number of times, and you may switch between different subway lines if you wish. All subway lines go in both directions.

Input

Input consists of the x,y coordinates of your home and your school, followed by specifications of several subway lines. Each subway line consists of the non-negative integer x,y coordinates of each stop on the line, in order. You may assume the subway runs in a straight line between adjacent stops, and the coordinates represent an integral number of metres. Each line has at least two stops. The end of each subway line is followed by the dummy coordinate pair -1,-1. In total there are at most 200 subway stops in the city.

Output

Output is the number of minutes it will take you to get to school, rounded to the nearest minute, taking the fastest route.

Sample Input

0 0 10000 1000

0 200 5000 200 7000 200 -1 -1

2000 600 5000 600 10000 600 -1 -1

Sample Output

21

Http

POJ:https://vjudge.net/problem/POJ-2502

NBUT:https://vjudge.net/problem/NBUT-1440

SCU:https://vjudge.net/problem/SCU-2186

Source

图论,最短路径

题目大意

给出家和学校的坐标以及若干条地铁线及地铁站,并给出人走路和坐地铁的速度,求从家到学校的最短时间。

解决思路

算法还是比较好想,就是直接跑最短路就可以,但是有些细节比较麻烦。

首先,只有相邻的地铁站可以通过地铁相连,其他的点都要计算欧几里得距离。

另外,最后输出答案只要整数部分,这点题目中并没有说明。

代码

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<stack>
#include<cmath>
using namespace std; const int maxN=300;
const int maxM=maxN*maxN;
const double v1=10000.0/60.0;//人的速度,均统一转换成m/min单位
const double v2=40000.0/60.0;//地铁的速度
const int inf=2147483647; class Pos//坐标的结构体
{
public:
int x,y;
}; int n,m;
class Graph//图
{
private:
int cnt;
int Head[maxN];
int Next[maxM];
int V[maxM];
double W[maxM];
bool instack[maxN];
stack<int> S;//听说spfa+stack快于spfa+queue
public:
double Dist[maxN];//距离
void init()
{
cnt=0;
memset(Head,-1,sizeof(Head));
memset(Next,-1,sizeof(Next));
}
void Add_Edge(int u,int v,double w)
{
cnt++;
Next[cnt]=Head[u];
V[cnt]=v;
W[cnt]=w;
Head[u]=cnt;
}
void spfa(int s)//Spfa
{
memset(Dist,127,sizeof(Dist));
memset(instack,0,sizeof(instack));
Dist[s]=0;
instack[s]=1;
S.push(s);
do
{
int u=S.top();
S.pop();
instack[u]=0;
for (int i=Head[u];i!=-1;i=Next[i])
{
if (Dist[V[i]]>Dist[u]+W[i])
{
Dist[V[i]]=Dist[u]+W[i];
if (instack[V[i]]==0)
{
instack[V[i]]=1;
S.push(V[i]);
}
}
}
}
while (!S.empty());
}
void OutEdge()//为了方便检查输出的边
{
for (int i=1;i<=n;i++)
{
for (int j=Head[i];j!=-1;j=Next[j])
{
cout<<i<<"->"<<V[j]<<' '<<W[j]<<endl;
}
cout<<endl;
}
}
}; Pos P[maxN];
Graph G; int read();
inline double Dist(Pos A,Pos B);
istream &operator >> (istream &is,Pos &p)//方便读入,重载一下输入运算符
{
is>>p.x>>p.y;
return is;
} int main()
{
cin>>P[1]>>P[2];
G.init();
n=2;
while (cin>>P[n+1])//输入处理,有些麻烦
{
n++;
int now=n;
Pos input;
for (int i=1;i<=n;i++)
{
double dist=Dist(P[n],P[i])/v1;
G.Add_Edge(n,i,dist);
G.Add_Edge(i,n,dist);
}
while (cin>>input)
{
if (input.x==-1)
break;
n++;
P[n]=input;
double dist=Dist(P[n],P[n-1])/v2;
G.Add_Edge(n,n-1,dist);
G.Add_Edge(n-1,n,dist);
for (int i=1;i<=n;i++)
{
//cout<<"Link:"<<i<<' '<<n<<endl;
double dist2=Dist(P[n],P[i])/v1;
G.Add_Edge(n,i,dist2);
G.Add_Edge(i,n,dist2);
}
}
}
//G.OutEdge();
G.spfa(1);
printf("%.0f\n",G.Dist[2]);
return 0;
} int read()
{
int x=0;
int k=1;
char ch=getchar();
while (((ch>'9')||(ch<'0'))&&(ch!='-'))
ch=getchar();
if (ch=='-')
{
k=-1;
ch=getchar();
}
while ((ch>='0')&&(ch<='9'))
{
x=x*10+ch-48;
ch=getchar();
}
return x*k;
} inline double Dist(Pos A,Pos B)
{
return sqrt((double)((A.x-B.x)*(A.x-B.x)+(A.y-B.y)*(A.y-B.y)));
}

按照我这个方法建出来的图会有部分边重复,但没有关系。

POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离)的更多相关文章

  1. POJ 2502 Subway(迪杰斯特拉)

    Subway Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6692   Accepted: 2177 Descriptio ...

  2. POJ 2502 Subway (Dijkstra 最短+建设规划)

    Subway Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6689   Accepted: 2176 Descriptio ...

  3. POJ 2502 Subway

    Subway Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4928   Accepted: 1602 Descriptio ...

  4. POJ 2502 - Subway Dijkstra堆优化试水

    做这道题的动机就是想练习一下堆的应用,顺便补一下好久没看的图论算法. Dijkstra算法概述 //从0出发的单源最短路 dis[][] = {INF} ReadMap(dis); for i = 0 ...

  5. POJ 2502 Subway (最短路)

    Subway 题目链接: http://acm.hust.edu.cn/vjudge/contest/122685#problem/L Description You have just moved ...

  6. (简单) POJ 2502 Subway,Dijkstra。

    Description You have just moved from a quiet Waterloo neighbourhood to a big, noisy city. Instead of ...

  7. POJ 2502 Subway-经过预处理的最短路

    Description You have just moved from a quiet Waterloo neighbourhood to a big, noisy city. Instead of ...

  8. Subway POJ 2502

    题目链接: http://poj.org/problem?id=2502 题目大意: 你刚从一个安静的小镇搬到一个吵闹的大城市,所以你不能再骑自行车去上学了,只能乘坐地铁或者步行去上学.因为你不想迟到 ...

  9. Dijkstra+计算几何 POJ 2502 Subway

    题目传送门 题意:列车上行驶40, 其余走路速度10.问从家到学校的最短时间 分析:关键是建图:相邻站点的速度是40,否则都可以走路10的速度.读入数据也很变态. #include <cstdi ...

随机推荐

  1. Android开发——官方推荐使用DialogFragment替换AlertDialog

    )比如当屏幕旋转时,AlertDialog会消失,更不会保存如EditText上的文字,如果处理不当很可能引发异常,因为Activity销毁前不允许对话框未关闭.而DialogFragment对话框会 ...

  2. AWK处理数组

    转自ChinaUnix论坛,感谢作者整理. 在文本处理的工作中,awk的数组是必不可少的工具,在这里,同样以总结经验和教训的方式和大家分享下我的一些学习心得,如有错误的地方,请大家指正和补充. awk ...

  3. 【转载】C++引用详解

    原文:http://www.cnblogs.com/gw811/archive/2012/10/20/2732687.html 引用的概念 引用:就是某一变量(目标)的一个别名,对引用的操作与对变量直 ...

  4. HDU-6356 Glad You Came (线段树)

    题目链接:Glad You Came 题意:数组有n个数初始为0,m个询问,每个询问给出L R V(按照给定函数生成),将数组的下标L到R的数与V取较大值,最后输出给定的公式结果. 题意:哇~打比赛的 ...

  5. P2463 [SDOI2008]Sandy的卡片

    写一种\(O(nm)\)的做法,也就是\(O(\sum 串长)\)的. 先通过差分转化,把每个数变成这个数与上一个数的差,第一个数去掉,答案就是最长公共子串+1 按照套路把所有串拼起来,中间加一个分隔 ...

  6. Python提示信息表示内容

      =此页面列出了PyLint 1.1.0支持的所有消息,按消息文本排序.还有一个按消息代码排序的所有代码列表. E0001,F0001,W0511(消息不同) E0103:循环中%r不正确W1501 ...

  7. A1046. Shortest Distance(20)

    17/20,部分超时. #include<bits/stdc++.h> using namespace std; int N,x,pairs; int a,b; vector<int ...

  8. 学习笔记 | CDQ分治

    目录 前言 啥是CDQ啊(它的基本思想) 例题 后记 参考博文 前言 博主太菜了 学习快一年的OI了 好像没有什么会的算法 更寒碜的是 学一样还不精一样TAT 如有什么错误请各位路过的大佬指出啊感谢! ...

  9. 通过汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的

    秦鼎涛  <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 实验一 通过汇编一个简单的C程序,分析汇编代码 ...

  10. 【MOOC EXP】Linux内核分析实验一报告

    程涵  原创博客 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000  [反汇编一个简单的C程序]   实验 ...