2602 最短路径问题

时间限制: 1 s

空间限制: 32000 KB

题目等级 : 黄金 Gold

题解

题目描述 Description

平面上有n个点(n<=100),每个点的坐标均在-10000~10000之间。其中的一些点之间有连线。若有连线,则表示可从一个点到达另一个点,即两点间有通路,通路的距离为两点间的直线距离。现在的任务是找出从一点到另一点之间的最短路径。

输入描述 Input Description

第一行为整数n。

第2行到第n+1行(共n行),每行两个整数x和y,描述了一个点的坐标。

第n+2行为一个整数m,表示图中连线的个数。

此后的m行,每行描述一条连线,由两个整数i和j组成,表示第i个点和第j个点之间有连线。

最后一行:两个整数s和t,分别表示源点和目标点。

输出描述 Output Description

仅一行,一个实数(保留两位小数),表示从s到t的最短路径长度。

样例输入 Sample Input

5

0 0

2 0

2 2

0 2

3 1

5

1 2

1 3

1 4

2 5

3 5

1 5

样例输出 Sample Output

3.41

数据范围及提示 Data Size & Hint

分类标签 Tags 点此展开

Floyd 最短路 图论

提交:codevs:http://codevs.cn/problem/2602/

思路分析:按照输入顺序建立点集,存储点的横纵坐标,图的话因为是Floyd,只能用邻接矩阵(或许是我太蒟了?orz),反正只有100个点,数组开到100*100就够了,因为只需要存储这100个点之间的关系,内存占用大约336KB,不会MLE(空间限制32M)。只有100个点,数据太小了,用FloydO(n)=100^3=1 000 000也不会TLE,关键还是以好写为主嘛。然后se都是编号,只需要在图中寻找就好了。这题关键在于处理好图与点的关系。

附:不同算法对不同图的适用性(时间复杂度以O=10^8为限,约合1s):

算法(特性)

算法复杂度

极限

Floyd(慢,适用于负边)

通值:V^3

E无关,通值:V<463

Dijkstra(不能处理负边权)

期望:V^2

最差:|E|+|V|log|V|

E, N均有关,期望:V<9999 最差:V<9998

SPFA(对于稠密图退化为Bellman - Ford算法)

期望:kEk为常数,常见为2)最差:|V|*|E|

V, E均有关,期望:V<5^7 最差:V<463

注:可以生成数据专门卡SPFA,如超稠密图、网格图等等,此时k会变得非常大,SPFA算法非常慢(|V|*|E|,等同于Floyd)。所以说SPFA算法是一种非常不稳定的算法(想要推翻前述观点请证明k的取值范围)。以下为维基百科原话:

以下是构建数据以破坏该算法的方法(不使用队列优化)。假设要求从顶点1到顶点n的最短路径。然后,我们可以用1i<n的小随机权重来添加边(ii + 1)(因此最短路径应为1-2 -...n),并随机添加4n个其他重边。对于这种情况,所谓的SPFA算法将非常慢。

附:两篇国家队论文,供有能力并且有兴趣的同学看看,内容主要是对于最短路算法优化的讨论(感谢jbyyym两位前辈!):

SPFA算法的优化及应用(by jby)

https://wenku.baidu.com/view/9e1231126edb6f1aff001f25.html

最短路算法及其应用(by yym)

https://wenku.baidu.com/view/7b2134c30c22590102029d27.html

(当然省选阶段前卡SPFA算法的题目是很少的,但还是要熟记Dijkstra算法,毕竟是一种十分稳定的算法,并且堆优化后跑得很快。要注意数据范围,大数据直接上SPFA;数据在10^4数量级上,保险起见还是用Dijkstra算法。)

代码(如果看不清楚就调整缩放比例到150%吧):

来一波数据黑一下SPFA

(I). 数据

1000 999000

1 2 1

1 3 1

1 1000 1

2 1 1

999 1000 1

1 1000

 

(数据量:10.2M)

(II). 实测:

略,这是SPFA的最差情况——完全图。

codevs 2602 最短路径问题——良心题解的更多相关文章

  1. Codevs 2602 最短路径问题

     时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题目描述 Description 平面上有n个点(n<=100),每个点的坐标均在-10000~10000之间. ...

  2. codevs 2602 最短路径问题x

                         题目描述 Description 平面上有n个点(n<=100),每个点的坐标均在-10000~10000之间.其中的一些点之间有连线.若有连线,则表示 ...

  3. codevs 1814 最长链题解

    codevs 1814 最长链题解 题目描述 Description 现给出一棵N个结点二叉树,问这棵二叉树中最长链的长度为多少,保证了1号结点为二叉树的根. 输入描述 Input Descripti ...

  4. code vs 2602 最短路径问题

    题目描述 Description 平面上有n个点(n<=100),每个点的坐标均在-10000~10000之间.其中的一些点之间有连线.若有连线,则表示可从一个点到达另一个点,即两点间有通路,通 ...

  5. 2602 最短路径问题Dihstra算法

    题目描述 Description 平面上有n个点(n<=100),每个点的坐标均在-10000~10000之间.其中的一些点之间有连线.若有连线,则表示可从一个点到达另一个点,即两点间有通路,通 ...

  6. 洛谷 1373 dp 小a和uim之大逃离 良心题解

    洛谷 1373 dp 这题还不算太难,,当初看的时候不是很理解题意,以为他们会选择两条不同的路径,导致整体思路混乱 传送门 其实理解题意和思路之后还是敲了不短的时间,一部分身体原因再加上中午休息不太好 ...

  7. BZOJ1876:[SDOI2009]SuperGCD——C++高精度良心题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=1876 Description Sheng bill有着惊人的心算能力,甚至能用大脑计算出两个巨大的数 ...

  8. CCF-CSP认证 C++题解目录

    持续更新中,记录刷题过程并分享一下小小的心得总结. 试题编号 试题名称 标签 202006-1 线性分类器 | 题解 线性规划 202006-2 稀疏向量| 题解 归并排序思想 202006-3 化学 ...

  9. 【第41套测试题NOIP2007】【排序】【DP】【高精度】【树】【图上路径】

    先说点题外话,这两天的入学考试,炸了……语文有史以来最差,数学有史以来最差……还有4科,估计全炸……悲痛的心情,来调程序.这套题是8.31考的,从昨天晚上开始改的,因为第三题迟迟不想写,才拖到了现在. ...

随机推荐

  1. Linux内核剖析 之 进程简单介绍

    1.概念 1.1  什么是进程?     进程是程序运行的一个实例.能够看作充分描写叙述程序已经运行到何种程度的数据结构的汇集.     从内核观点看.进程的目的就是担当分配系统资源(CPU时间,内存 ...

  2. 【Linux学习】Ubuntu下 sambaserver搭建

    1.安装samba,smbfs 2.配置smb.conf文件 配置文件之前须要先备份一下须要配置的文件(养成好的习惯) 输入命令: 进入到smb.conf文件里,在文件的最后加入下列语句 保存后.退出 ...

  3. 2015 年度新增开源软件排名TOP100

    本榜单包括 2015 年开源中国新收录的 5977 款开源软件中,依据软件本身的关注度.活跃程度进行排名前 100 名的软件.从这份榜单中也许能够了解到最新业界的趋势. 1.SwitchyOmega ...

  4. Lightoj 1235 - Coin Change (IV) 【二分】

    题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1235 题意: 有N个硬币(N<=18).问是否能在每一个硬币使用不超过两 ...

  5. Golang Template source code analysis(Parse)

    This blog was written at go 1.3.1 version. We know that we use template thought by followed way: fun ...

  6. alsa 用户空间编程【转】

    本文转载自:http://blog.csdn.net/sjin_1314/article/details/12872581 /**alsa play test *ALSA用户空间编译,ALSA驱动的声 ...

  7. Codeforces--630K--Indivisibility(容斥)

     K - Indivisibility Crawling in process... Crawling failed Time Limit:500MS     Memory Limit:65536 ...

  8. 七牛php上传下载类,集成官方文档的方法

    <?phpuse Qiniu\Auth;use Qiniu\Storage\UploadManager;class qiniu{ public $_accesskey = null; publi ...

  9. sklearn中的数据预处理和特征工程

    小伙伴们大家好~o( ̄▽ ̄)ブ,沉寂了这么久我又出来啦,这次先不翻译优质的文章了,这次我们回到Python中的机器学习,看一下Sklearn中的数据预处理和特征工程,老规矩还是先强调一下我的开发环境是 ...

  10. rabbitmq普通集群搭建详细步骤

    由于工作需求,需要安装rabbitmq,学习之余,记录一下安装过程 准备基础编译环境yum install gcc glibc-devel make ncurses-devel openssl-dev ...