[SinGuLaRiTy] 最短路计算代码库
【SinGuLaRiTy-1002】 Copyright (c) SinGuLaRiTy 2017. All Rights Reserved.
Dijkstra:
题目描述
有向图的单源点最短路问题(Dijkstra算法)
输入
第1行:2个空格分开的整数n(2<=n<=500)和m(10<=m<=20000),分别表示图的顶点数和边数。
第2..m+1行:每行3个空格分开的整数i,j, w。i表示一条边的起点,j表示终点, w表示权值。
第m+2行:2个整数s,t(1<=s,t<=n),表示指定的顶点。
输出
第1行:最小距离
第2行:最短路径(从起点到终点的序列,用1个空格分开)
| 样例输入 | 样例输出 |
|
5 7 1 2 10 1 4 30 1 5 100 2 3 50 3 5 10 4 3 20 4 5 60 1 5 |
60 1 4 3 5 |
代码:
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
using namespace std;
int n,m;
int G[][],dis[],L[];
bool used[];
void Dijkstra(int s)
{
for(int i=;i<=n;i++)
{
used[s]=;
for(int j=;j<=n;j++)
{
if(G[s][j]==||s==j)
continue;
if(dis[j]>dis[s]+G[s][j])
dis[j]=dis[s]+G[s][j],L[j]=s;
}
int themin=0x3f3f3f3f;
for(int i=;i<=n;i++)
if(used[i]==&&dis[i]<themin)
s=i,themin=dis[i];
}
}
int main()
{
int a,b,c,S,E,cnt=;
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&a,&b,&c);
G[a][b]=c;
}
scanf("%d%d",&S,&E);
int e=E;
dis[S]=;
for(int i=;i<=n;i++)
if(i!=S) dis[i]=0x3f3f3f3f; Dijkstra(S); printf("%d\n",dis[E]);
while(L[E]!=)
{
dis[cnt++]=L[E];
E=L[E];
}
for(int i=cnt-;i>=;i--)
printf("%d ",dis[i]);
printf("%d",e);
return ;
}
SPAF:
题目描述
有向图的单源点最短路径问题。源点编号为1,终点编号为n。
输入
第1行:2个空格分开的整数n(2<=n<=5000)和m(10<=m<=500000),分别表示图的顶点数和边数。
第2..m+1行:每行3个空格分开的整数i,j, w。i表示一条边的起点,j表示终点, w表示权值。
输出
第1行:1个整数,表示最小距离
| 样例输入1 | 样例输出1 |
|
4 7
1 2 68
1 3 19
1 4 66
2 3 23
3 4 65
3 2 57
4 1 68
|
66 |
|
样例输入 |
样例输出 |
|
3 3
1 2 -7
2 3 4
3 1 2
|
No Solution |
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
struct node{
int v,w,next;
}edge[];
int cnt,head[],n,m,dis[],tot[];
bool inq[];
void addedge(int u,int v,int w)
{
edge[cnt].v=v;
edge[cnt].w=w;
edge[cnt].next=head[u];
head[u]=cnt++;
}
bool SPFA()
{
memset(dis,0x3f,sizeof dis);
dis[]=;
inq[]=;
deque<int>q;
q.push_front();
while(!q.empty())
{
int u=q.front();
q.pop_front();
inq[u]=;
for(int i=head[u];i!=-;i=edge[i].next)
{
int v=edge[i].v,w=edge[i].w;
if(dis[v]>dis[u]+w)
{
dis[v]=dis[u]+w;
if(!inq[v])
{
if(dis[v]<dis[u])q.push_front(v);
else q.push_back(v);
inq[v]=;
if(++tot[v]>n)return ;
}
}
}
}
return ;
}
int main()
{
int u,v,w;
scanf("%d%d",&n,&m);
memset(head,-,sizeof head);
for(int i=;i<=m;++i)
{
scanf("%d%d%d",&u,&v,&w);
addedge(u,v,w);
}
SPFA()?printf("%d\n",dis[n]):
puts("No Solution");
}
Floyd:
代码:
#include<cstdio>
#include<cstring>
#define maxn 100
#define INF -1
int map[maxn][maxn];
int n, m, path[maxn][maxn]; void Floyd(int n)
{
int i, j, k;
for(k = ; k < n; ++k)
for(i = ; i < n; ++i)
for(j = ; j < n; ++j)
if(map[i][k] != INF && map[k][j] != INF && (map[i][k] + map[k][j] < map[i][j] || map[i][j] == INF)){
map[i][j] = map[i][k] + map[k][j];
path[i][j] = k;
}
} void getPath(int v, int u)
{
int k = path[v][u];
if(k == INF){
printf("%d===>", v);
return;
}
getPath(v, k);
getPath(k, u);
} int main()
{
scanf("%d%d", &n, &m);
memset(map, INF, sizeof(map));
memset(path, INF, sizeof(path));
int i, j, a, b, c;
for(i = ; i < n; ++i) map[i][i] = ;
for(i = ; i < m; ++i){
scanf("%d%d%d", &a, &b, &c);
map[a][b] = c;
}
Floyd(n);
for(i = ; i < n; ++i)
for(j = ; j < n; ++j)
if(map[i][j] != INF){
printf("%d->%d:%d\n the path is:", i, j, map[i][j]);
getPath(i, j);
printf("%d\n", j);
}
return ;
}
BellmanFord:
题目描述
有向图负权的单源点最短路问题(BellmanFord 算法),如果最短路径有多条,输出路径经过边数较小的解; 如果最短路径边数相同,输出编号较小的序列.
输入
第1行:2个空格分开的整数n(2<=n<=500)和m(10<=m<=20000),分别表示图的顶点数和边数。
第2..m+1行:每行3个空格分开的整数i,j, w。i表示一条边的起点,j表示终点, w表示权值。
第m+2行:2个整数s,t(1<=s,t<=n),表示指定的顶点。
输出
第1行:最小距离
第2行:最短路径(从起点到终点的序列,用1个空格分开)
如果出现负权回路,输出:No Solution
| 样例输入 | 样例输出 |
| 6 7 1 2 2 1 3 -1 2 4 -3 3 4 3 3 6 7 4 6 -2 3 5 6 1 6 |
-3 1 2 4 6 |
代码:
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int f[][],dis[],s[];
void print(int x)
{
if(s[x]==) return;
print(s[x]);
printf(" %d",x);
}
int main()
{
int n,m,i,j,q,z;
scanf("%d%d",&n,&m);
for(i=;i<=m;i++)
scanf("%d%d%d",&f[i][],&f[i][],&f[i][]);
scanf("%d%d",&q,&z);
memset(dis,,sizeof(dis));
dis[q]=;
for(i=;i<=n;i++){
for(j=;j<=m;j++){
if(dis[f[j][]]+f[j][]<dis[f[j][]]&&i<n){
dis[f[j][]]=dis[f[j][]]+f[j][];
s[f[j][]]=f[j][];
}
if(i==n&&dis[f[j][]]+f[j][]<dis[f[j][]]){
printf("No Solution");
return ;
}
}
}
printf("%d\n",dis[z]);
printf("%d",q);
print(z);
}
Time:2017-02-03
[SinGuLaRiTy] 最短路计算代码库的更多相关文章
- Overview of the Oppia codebase(Oppia代码库总览)
Oppia is built with Google App Engine. Its backend is written in Python, and its frontend is written ...
- Python中的短路计算
在Python中,布尔类型还可以与其他数据类型做 and.or和not运算,请看下面的代码: In [1]: a = True In [2]: print(a and 'a=T' or 'a=F') ...
- 如何统计TFS代码库中的团队项目所占用的磁盘空间
在一个开发团队较多的研发中心,当开发人员的代码数据积累到一定程度,TFS系统的磁盘空间的使用率会逐渐成为系统管理员关注的问题.你可能会关注代码库中每个团队项目,甚至每个目录占用的的磁盘空间.不幸的,即 ...
- minizip -基于zlib开源代码库
转载:https://www.topomel.com/archives/979.html 一.minizip 是一套用来压缩和解压文件的工具,其基于zlib开源代码库. 开源代码下载链接:http:/ ...
- python之短路计算-布尔类型
Python中布尔类型 我们已经了解了Python支持布尔类型的数据,布尔类型只有True和False两种值,但是布尔类型有以下几种运算: 与运算:只有两个布尔值都为 True 时,计算结果才为 Tr ...
- [java代码库]-简易计算器(第二种)
[java代码库]-简易计算器(第二种) 第二种方案:在程序中不使用if/switch……case等语句,完成计算器功能. <html> <head> <title> ...
- python学习--大数据与科学计算第三方库简介
大数据与科学计算 库名称 简介 pycuda/opencl GPU高性能并发计算 Pandas python实现的类似R语言的数据统计.分析平台.基于NumPy和Matplotlib开发的,主要用于 ...
- python 科学计算基础库安装
1.numpyNumPy(Numeric Python)是用Python进行科学计算的基本软件包. NumPy是Python编程语言的扩展,增加了对大型多维数组和矩阵的支持,以及一个大型的高级数学函数 ...
- iOS流行的开源代码库
本文介绍一些流行的iOS的开源代码库 1.AFNetworking 更新频率高的轻量级的第三方网络库,基于NSURL和NSOperation,支持iOS和OSX.https://github.com/ ...
随机推荐
- ACM入门:第s名的小红
前几天的大一新生赛自己也跟着做了做,顺便测测后台数据有没有bug,这是一道排序题,题目如下: Problem Description 小红总是排第二,有点不服气,现在她想知道一个序列中第二小的数字是多 ...
- 丘吉尔,最后一次演讲-Never Give Up
丘吉尔一生最精彩的演讲,也是他最后一次演讲.在剑桥大学的一次毕业典礼上,整个会堂有上万个学生,他们正在等待丘吉尔的出现.正在这时,丘吉尔在他的随从陪同下走进了会场并慢慢走向讲台,他脱下他的大衣交给随从 ...
- iOS使用StroryBoard页面跳转及传值
之前在网上iOS的页面跳转大多都是按回以前的那种xib的形式,但鄙人是使用storyboard的.这篇就只介绍利用storyboard进行页面跳转与传值. 新建页面 iOS的程序也是使用了MVC的思想 ...
- 深入探讨 CSS 特性检测 @supports 与 Modernizr
什么是 CSS 特性检测?我们知道,前端技术日新月异的今天,各种新技术新属性层出不穷.在 CSS 层面亦不例外. 一些新属性能极大提升用户体验以及减少工程师的工作量,并且在当下的前端氛围下: 很多实验 ...
- 【转】Nutch的Hadoop方式爬取效率优化
原文地址:http://my.oschina.net/junfrank/blog/290404
- 使用JS实现手风琴效果
想要实现简单的手风琴切换效果,需要使用JS实现,如下是使用javascript源码实现,后续会更新使用jQuery实现. 1. 先进行简单的布局:我们可以再ul下添加几个li实现html的简单布局,再 ...
- window编程之win程序框架
int APIENTRY _tWinMain(_In_ HINSTANCE hInstance, _In_opt_ HINSTANCE hPrevInstance, _In_ LPTSTR lpCmd ...
- iOS应用 跳转到系统的设置界面
现在很多APP都需要获取用户权限,例如,允许调用位置信息,读取短信,拨打电话,开启WIFI,掉头摄像头等,用户不允许APP获取这些权限的时候.最好的用户体验是,直接跳转到系统设置界面,让用户自己设置. ...
- 概念 : 用户>角色>权限 的管理(Role-Based Access Control)
RBAC 用户管理规范 概念:每个user有多个accounts,每个account 有一个account binding,有多个roles和多个tasks 举个例子:某个用户现在manager,这是 ...
- Androidstudio项目分享到Git@OSC托管
Androidstudio项目分享到Git@OSC托管. 一.在OSC创建仓库 例如,创建一个AndroidStudy仓库,创建步骤如下: 输入仓库名称 点击创建按钮,就可以完成仓库的创建,如下图所示 ...