forked from kelvins/algorithms-and-data-structures
-
Notifications
You must be signed in to change notification settings - Fork 0
/
AlgoritmoDijkstra.c
99 lines (85 loc) · 3.84 KB
/
AlgoritmoDijkstra.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*
* Graphs - Dijkstra Algorithm in C
* Kelvin Salton do Prado - 2015
* Complexity: Theta(n^2)
*
* 1 for all - Edges with non-negative weights - Greedy algorithm
* Finds the shortest path from one vertex (start) to another (destination)
*
* Graph with 5 vertices and 6 edges
*
* 6
* (0)-----------------(1)
* | |
* 10 | | 2
* | 1 |
* (2)-----------------(3)
* \ /
* 3 \ / 8
* \ /
* -----(4)-----
*
* Distance Matrix
* 0 1 2 3 4
* 0 0 6 10 - -
* 1 6 0 - 2 -
* 2 10 - 0 1 3
* 3 - 2 1 0 8
* 4 - - 3 8 0
*
* For infinite values, the value will be considered: 4294967295
* The objective is to leave the starting point (0) and reach the destination (4) by the shortest route
* Response: (0)->(1)->(3)->(2)->(4) = 12
*
*/
#include <stdio.h>
#include <stdbool.h>
#define noVertices 5 // Defines a constant 5 which is the number of vertices in the graph
// Dijkstra's algorithm takes as parameters the distance matrix and the number of vertices
void Dijkstra(unsigned long int matrix[noVertices][noVertices], int n){
bool visited[n]; // Variable that holds true for visited vertices
// The value 'i' from the for below is not used, as the for is only used to traverse the entire number of columns in the matrix
for(int i = 1; i < n; i++){ // Starts at 1 because you don't need to compare the vertex with itself
int min = -1; // Variable that stores the position of the smallest value, starts at -1 as it is an invalid position
unsigned long int MinValue = 4294967295; // Variable that stores the smallest value found, starts with 'infinity', so always on the first pass the value will be smaller than this variable
// For that loops through all rows in column [0]
for(int j = 1; j < n; j++){
// If the vertex has not yet been visited and the value is less than the 'MinValor'
if( !visited[j] && matrix[j][0] < MinValue ){
min = j; // Saves the position of the smallest
MinValue = matrix[j][0]; // Save the smallest value
}
}
visited[min] = true; // Mark the value of the minimum position as visited
// Goes from 1 to n
for(int j = 1; j < n; j++){
// If the value of column [0] + the value of the passing column is less than the value of the passing row and column [0]
// Update the first column of the matrix, which will be used for the next iterations
if( (matrix[min][0] + matrix[min][j]) < matrix[j][0] ){
matrix[j][0] = matrix[min][0] + matrix[min][j];
}
}
}
}
int main(){
unsigned long int Matrix[noVertices][noVertices] = {{ 0, 6, 10, 4294967295, 4294967295 },
{ 6, 0, 4294967295, 2, 4294967295 },
{ 10, 4294967295, 0, 1, 3 },
{ 4294967295, 2, 1, 0, 8 },
{ 4294967295, 4294967295, 3, 8, 0 }};
Dijkstra(Matrix, noVertices);
printf("Total shortest path from vertex 0 to 4: %lu\n", Matrix[4][0]); // Shortest total path
// Print the matrix with the updated values
printf("Matrix:\n");
for (int i = 0; i < noVertices; ++i){
for (int e = 0; e < noVertices; ++e){
if( Matrix[i][e] < 10 )
printf(" %lu ", Matrix[i][e]);
else
printf("%lu ", Matrix[i][e]);
}
printf("\n");
}
printf("\n");
return 0;
}