Program to find Minimum Spanning Tree MST of a graph using Prim’s Algorithm in C

Program

// Prim's Algorithm in C
#include <stdio.h>
#include <stdbool.h>
#define INF 9999999
// number of vertices in graph
#define V 5
// create a 2d array of size 5x5
// for adjacency matrix to represent graph
int G[V][V] = {
    {0, INF, 75, 0, 0},
    {9, 0, 95, 19, 42},
    {75, 95, 0, 51, 66},
    {0, 19, 51, 0, 31},
    {0, INF, 66, 31, 0}};
int main()
{
    int no_edge; // number of edge
    printf("****************************************************************");
    printf("\n****************************************************************");
    printf("\n**      WAP to find Minimum Spanning Tree MST of a graph      **");
    printf("\n**                 using Prim's Algorithm in C                **");
    printf("\n**                   Created by Sheetal Garg                  **");
    printf("\n**                     Assistant Professor                    **");
    printf("\n**                     Phone No:9467863365                    **");
    printf("\n****************************************************************");
    printf("\n****************************************************************");
    // create a array to track selected vertex
    // selected will become true otherwise false
    int selected[V];
    // set selected false initially
    memset(selected, false, sizeof(selected));
    // set number of edge to 0
    no_edge = 0;
    // the number of egde in minimum spanning tree will be
    // always less than (V -1), where V is number of vertices in
    // graph
    // choose 0th vertex and make it true
    selected[0] = true;
    int x; //  row number
    int y; //  col number
    // print for edge and weight
    printf("\nEdge : Weight\n");
    while (no_edge < V - 1)
    {
        // For every vertex in the set S, find the all adjacent vertices
        //  , calculate the distance from the vertex selected at step 1.
        //  if the vertex is already in the set S, discard it otherwise
        // choose another vertex nearest to selected vertex  at step 1.
        int min = INF;
        x = 0;
        y = 0;
        for (int i = 0; i < V; i++)
        {
            if (selected[i])
            {
                for (int j = 0; j < V; j++)
                {
                    if (!selected[j] && G[i][j])
                    { // not in selected and there is an edge
                        if (min > G[i][j])
                        {
                            min = G[i][j];
                            x = i;
                            y = j;
                        }
                    }
                }
            }
        }
        printf("%d - %d : %d\n", x, y, G[x][y]);
        selected[y] = true;
        no_edge++;
    }
    return 0;
}

Output

****************************************************************
****************************************************************
**      WAP to find Minimum Spanning Tree MST of a graph      **
**                 using Prim's Algorithm in C                **
**                   Created by Sheetal Garg                  **
**                     Assistant Professor                    **
**                     Phone No:9467863365                    **
****************************************************************
****************************************************************
Edge : Weight
0 - 2 : 75
2 - 3 : 51
3 - 1 : 19
3 - 4 : 31
error: You can only copy the programs code and output from this website. You are not allowed to copy anything else.