[算法] dijkstra单源无负权最小路径算法
#include <stdio.h>
#include <stdlib.h>
#include <string.h> #define INF 1000000
#define MAXN 32 int N;
int matrix[MAXN][MAXN]; int dist[MAXN];
int path[MAXN];
int s[MAXN]; void dijkstra(int u){
/* init */
int i, j, k;
int min;
int v;
int tmp; for(i =0; i < N; i++){
s[i]=0;
dist[i]= matrix[u][i];
if(dist[i]!= INF && i != u){
path[i]= u;
}
else{
path[i]=-1;
}
}
s[u]=1;
dist[u]=0;
for(i =1; i < N; i++){
min = INF;
for(j =0; j < N; j++){
if(!s[j]&& dist[j]< min){
min = dist[j];
v = j;
}
}
s[v]=1;
for(k =0; k < N; k++){
if(s[k]){
continue;
}
tmp = dist[v]+ matrix[v][k];
if(dist[k]> tmp){
dist[k]= tmp;
path[k]= v;
}
}
}
} void print_path(int u){
int rev[MAXN];
int count =0;
int i;
int v;
memset(rev,0,sizeof(rev)); rev[count++]= u;
v = path[u];
while(v !=-1){
rev[count ++]= v;
v = path[v];
} for(i = count -1; i >=0; i--){
if(i == count -1){
printf("%d", rev[i]);
}
else{
printf("->%d", rev[i]);
}
}
} int main(){
int i, j;
int u, v, w;
scanf("%d",&N);
memset(matrix,0,sizeof(matrix));
while(1){
scanf("%d%d%d",&u,&v,&w);
if(u ==-1&& v ==-1&& w ==-1){
break;
}
matrix[u][v]= w;
}
for(i =0; i < N; i++){
for(j =0; j < N; j++){
if(i == j){
matrix[i][j]=0;
}
elseif(matrix[i][j]==0){
matrix[i][j]= INF;
}
}
}
dijkstra(0);
for(i =1; i < N; i++){
printf("%d-->%d:%d\t",0, i, dist[i]);
print_path(i);
printf("\n");
}
return0;
}
[算法] dijkstra单源无负权最小路径算法的更多相关文章
- 【算法】Dijkstra算法(单源最短路径问题)(路径还原) 邻接矩阵和邻接表实现
Dijkstra算法可使用的前提:不存在负圈. 负圈:负圈又称负环,就是说一个全部由负权的边组成的环,这样的话不存在最短路,因为每在环中转一圈路径总长就会边小. 算法描述: 1.找到最短距离已确定的顶 ...
- 【算法】单源最短路径和任意两点最短路径总结(补增:SPFA)
[Bellman-Ford算法] [算法]Bellman-Ford算法(单源最短路径问题)(判断负圈) 结构: #define MAX_V 10000 #define MAX_E 50000 int ...
- 图之单源Dijkstra算法、带负权值最短路径算法
1.图类基本组成 存储在邻接表中的基本项 /** * Represents an edge in the graph * */ class Edge implements Comparable< ...
- Dijkstra 单源最短路径算法
Dijkstra 算法是一种用于计算带权有向图中单源最短路径(SSSP:Single-Source Shortest Path)的算法,由计算机科学家 Edsger Dijkstra 于 1956 年 ...
- 【算法】单源最短路——Dijkstra
对于固定起点的最短路算法,我们称之为单源最短路算法.单源最短路算法很多,最常见的就是dijkstra算法. dijkstra主要用的是一种贪心的思想,就是说如果i...s...t...j是最短路,那么 ...
- [数据结构与算法-15]单源最短路径(Dijkstra+SPFA)
单源最短路径 问题描述 分别求出从起点到其他所有点的最短路径,这次主要介绍两种算法,Dijkstra和SPFA.若无负权优先Dijkstra算法,存在负权选择SPFA算法. Dijkstra算法 非负 ...
- Dijkstra——单源最短路径
算法思想 ①从一个源点开始,找距离它最近的点顶点v ②然后以顶点v为起点,去找v能到达的顶点w,即v的邻居 比较源点直接到 v的距离和(源点到v的距离+v到w的距离) 若大于后者则更新源点的到w的开销 ...
- 51nod 1445 变色DNA ( Bellman-Ford算法求单源最短路径)
1445 变色DNA 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题 有一只特别的狼,它在每个夜晚会进行变色,研究发现它可以变成N种颜色之一,将这些颜色标号为0,1 ...
- Til the Cows Come Home(poj 2387 Dijkstra算法(单源最短路径))
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 32824 Accepted: 11098 Description Bes ...
随机推荐
- Nginx配置文件nginx.conf中文详解【转】
PS:Nginx使用有两三年了,现在经常碰到有新用户问一些很基本的问题,我也没时间一一回答,今天下午花了点时间,结合自己的使用经验,把Nginx的主要配置参数说明分享一下,也参考了一些网络的内容,这篇 ...
- .net简单的静态页生成
1.得到实体对象model,读取模板 string htmlMaster = File.ReadAllText(HttpContext.Current.Server.MapPath("/ma ...
- 学习最短路建图 HUD 5521
http://acm.hdu.edu.cn/showproblem.php?pid=5521 题目大意:有n个点,m个集合,每个集合里面的点都两两可达且每条边权值都是val,有两个人A, B,A在po ...
- WPF(x:Null 使用)
<Window x:Class="TestOfNull.MainWindow" xmlns="http://schemas.microsoft.com/winfx/ ...
- UVA106 - Fermat vs. Pythagoras
假设x为奇数,y为偶数,则z为奇数,2z与2x的最大公因数为2,2z和2x可分别写作 2z = (z + x) + (z - x) 2x = (z + x) - (z - x) 那么跟据最大公因数性质 ...
- Camera Path插件的使用
rpg游戏类型的游戏,猪脚走过一个个场景,一个个死角.拐弯处,摄像机镜头也能很好的跟踪对焦,很多朋友都会想,这摄像机如何智能跟踪并且对焦呢? 之前 itween也有demo,但它做法是 两条线,一条摄 ...
- 两个byte[]拼接
//两个byte[]拼接 public byte[] copybyte(byte[] a, byte[] b, byte[] c, byte[] d, byte[] e)///,byte[] f,by ...
- 2016湖南省赛--A题--2016
2016 [TOC] Description 给出正整数 n 和 m,统计满足以下条件的正整数对 (a,b) 的数量: 1. 1≤a≤n,1≤b≤m; 2. a×b 是 2016 的倍数. Input ...
- PAT (Advanced Level) 1112. Stucked Keyboard (20)
找出一定没问题的字符(即一连串的额字符x个数能被k整除的),剩下的字符都是可能有问题的. #include<cstdio> #include<cstring> #include ...
- 随机法解决TSP问题
TSP问题一直是个头疼的问题,但是解决的方法数不胜数,很多的算法也都能解决.百度资料一大堆,但是我找到了代码比较简练的一种.随机法.下面只是个人的看法而已,如果有任何问题虚心接受. 顾名思义,随机法就 ...