STANAANDREY

dijkstra

Nov 7th, 2024
29
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 2.37 KB | None | 0 0
  1. // Dijkstra's Algorithm in C
  2.  
  3. #include <stdio.h>
  4. #define INFINITY 9999
  5. #define MAX 10
  6.  
  7. void Dijkstra(int Graph[MAX][MAX], int n, int start);
  8.  
  9. void Dijkstra(int Graph[MAX][MAX], int n, int start) {
  10.   int cost[MAX][MAX], distance[MAX], pred[MAX];
  11.   int visited[MAX], count, mindistance, nextnode, i, j;
  12.  
  13.   // Creating cost matrix
  14.   for (i = 0; i < n; i++)
  15.     for (j = 0; j < n; j++)
  16.       if (Graph[i][j] == 0)
  17.         cost[i][j] = INFINITY;
  18.       else
  19.         cost[i][j] = Graph[i][j];
  20.  
  21.   for (i = 0; i < n; i++) {
  22.     distance[i] = cost[start][i];
  23.     pred[i] = start;
  24.     visited[i] = 0;
  25.   }
  26.  
  27.   distance[start] = 0;
  28.   visited[start] = 1;
  29.   count = 1;
  30.  
  31.   while (count < n - 1) {
  32.     mindistance = INFINITY;
  33.  
  34.     for (i = 0; i < n; i++)
  35.       if (distance[i] < mindistance && !visited[i]) {
  36.         mindistance = distance[i];
  37.         nextnode = i;
  38.       }
  39.  
  40.     visited[nextnode] = 1;
  41.     for (i = 0; i < n; i++)
  42.       if (!visited[i])
  43.         if (mindistance + cost[nextnode][i] < distance[i]) {
  44.           distance[i] = mindistance + cost[nextnode][i];
  45.           pred[i] = nextnode;
  46.         }
  47.     count++;
  48.   }
  49.  
  50.   // Printing the distance
  51.   for (i = 0; i < n; i++)
  52.     if (i != start) {
  53.       printf("\nDistance from source to %d: %d", i, distance[i]);
  54.     }
  55. }
  56. int main() {
  57.   int Graph[MAX][MAX], i, j, n, u;
  58.   n = 7;
  59.  
  60.   Graph[0][0] = 0;
  61.   Graph[0][1] = 0;
  62.   Graph[0][2] = 1;
  63.   Graph[0][3] = 2;
  64.   Graph[0][4] = 0;
  65.   Graph[0][5] = 0;
  66.   Graph[0][6] = 0;
  67.  
  68.   Graph[1][0] = 0;
  69.   Graph[1][1] = 0;
  70.   Graph[1][2] = 2;
  71.   Graph[1][3] = 0;
  72.   Graph[1][4] = 0;
  73.   Graph[1][5] = 3;
  74.   Graph[1][6] = 0;
  75.  
  76.   Graph[2][0] = 1;
  77.   Graph[2][1] = 2;
  78.   Graph[2][2] = 0;
  79.   Graph[2][3] = 1;
  80.   Graph[2][4] = 3;
  81.   Graph[2][5] = 0;
  82.   Graph[2][6] = 0;
  83.  
  84.   Graph[3][0] = 2;
  85.   Graph[3][1] = 0;
  86.   Graph[3][2] = 1;
  87.   Graph[3][3] = 0;
  88.   Graph[3][4] = 0;
  89.   Graph[3][5] = 0;
  90.   Graph[3][6] = 1;
  91.  
  92.   Graph[4][0] = 0;
  93.   Graph[4][1] = 0;
  94.   Graph[4][2] = 3;
  95.   Graph[4][3] = 0;
  96.   Graph[4][4] = 0;
  97.   Graph[4][5] = 2;
  98.   Graph[4][6] = 0;
  99.  
  100.   Graph[5][0] = 0;
  101.   Graph[5][1] = 3;
  102.   Graph[5][2] = 0;
  103.   Graph[5][3] = 0;
  104.   Graph[5][4] = 2;
  105.   Graph[5][5] = 0;
  106.   Graph[5][6] = 1;
  107.  
  108.   Graph[6][0] = 0;
  109.   Graph[6][1] = 0;
  110.   Graph[6][2] = 0;
  111.   Graph[6][3] = 1;
  112.   Graph[6][4] = 0;
  113.   Graph[6][5] = 1;
  114.   Graph[6][6] = 0;
  115.  
  116.   u = 0;
  117.   Dijkstra(Graph, n, u);
  118.  
  119.   return 0;
  120. }
Add Comment
Please, Sign In to add comment