Here you will learn about prim’s algorithm in C with a program example.

Prim’s Algorithm is an approach to determine minimum cost spanning tree. In this case, we start with single edge of graph and we add edges to it and finally we get minimum cost tree. In this case, as well, we have n-1 edges when number of nodes in graph are n.We again and again add edges to tree and tree is extended to create spanning tree, while in case of Kruskal’s algorithm there may be more than one tree, which is finally connected through edge to create spanning tree.

**Also Read: Kruskal’s Algorithm for Finding Minimum Cost Spanning Tree**

**Also Read: Dijkstra Algorithm for Finding Shortest Path of a Graph**

### Algorithm

This algorithm creates spanning tree with minimum weight from a given weighted graph.

- Begin
- Create edge list of given graph, with their weights.
- Draw all nodes to create skeleton for spanning tree.
- Select an edge with lowest weight and add it to skeleton and delete edge from edge list.
- Add other edges. While adding an edge take care that the one end of the edge should always be in the skeleton tree and its cost should be minimum.
- Repeat step 5 until n-1 edges are added.
- Return.

## Program for Prim’s Algorithm in C

C program for constructing a minimum cost spanning tree of a graph using Prim’s algorithm is given below.

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 |
#include<stdio.h> #include<stdlib.h> #define infinity 9999 #define MAX 20 int G[MAX][MAX],spanning[MAX][MAX],n; int prims(); int main() { int i,j,total_cost; printf("Enter no. of vertices:"); scanf("%d",&n); printf("\nEnter the adjacency matrix:\n"); for(i=0;i<n;i++) for(j=0;j<n;j++) scanf("%d",&G[i][j]); total_cost=prims(); printf("\nspanning tree matrix:\n"); for(i=0;i<n;i++) { printf("\n"); for(j=0;j<n;j++) printf("%d\t",spanning[i][j]); } printf("\n\nTotal cost of spanning tree=%d",total_cost); return 0; } int prims() { int cost[MAX][MAX]; int u,v,min_distance,distance[MAX],from[MAX]; int visited[MAX],no_of_edges,i,min_cost,j; //create cost[][] matrix,spanning[][] for(i=0;i<n;i++) for(j=0;j<n;j++) { if(G[i][j]==0) cost[i][j]=infinity; else cost[i][j]=G[i][j]; spanning[i][j]=0; } //initialise visited[],distance[] and from[] distance[0]=0; visited[0]=1; for(i=1;i<n;i++) { distance[i]=cost[0][i]; from[i]=0; visited[i]=0; } min_cost=0; //cost of spanning tree no_of_edges=n-1; //no. of edges to be added while(no_of_edges>0) { //find the vertex at minimum distance from the tree min_distance=infinity; for(i=1;i<n;i++) if(visited[i]==0&&distance[i]<min_distance) { v=i; min_distance=distance[i]; } u=from[v]; //insert the edge in spanning tree spanning[u][v]=distance[v]; spanning[v][u]=distance[v]; no_of_edges--; visited[v]=1; //updated the distance[] array for(i=1;i<n;i++) if(visited[i]==0&&cost[i][v]<distance[i]) { distance[i]=cost[i][v]; from[i]=v; } min_cost=min_cost+cost[u][v]; } return(min_cost); } |

**Output**

*Enter no. of vertices:6*

*Enter the adjacency matrix:*

*0 3 1 6 0 0*

*3 0 5 0 3 0*

*1 5 0 5 6 4*

*6 0 5 0 0 2*

*0 3 6 0 0 6*

*0 0 4 2 6 0*

*spanning tree matrix:*

*0 3 1 0 0 0*

*3 0 0 0 3 0*

*1 0 0 0 0 4*

*0 0 0 0 0 2*

*0 3 0 0 0 0*

*0 0 4 2 0 0*

*Total cost of spanning tree=13*

#### Time Complexity

Prim’s algorithm contains two nested loops. Each of this loop has a complexity of O (n). Thus, the complexity of Prim’s algorithm for a graph having n vertices = O (n^{2}).

Comment below if you found anything incorrect or missing in above prim’s algorithm in C.

please give an explanation on the following snipet of the above code

u=from[v]; //what is u and v here…??

//insert the edge in spanning tree

spanning[u][v]=distance[v];

spanning[v][u]=distance[v];

no_of_edges–;

visited[v]=1;

//updated the distance[] array

for(i=1;i<n;i++)

if(visited[i]==0&&cost[i][v]<distance[i])

{

distance[i]=cost[i][v];

from[i]=v;

}

u is parent of v .After first initialization,parent is set from G[0][0] to G[0][v] .Since it is undirected graph we have to set equal values in both direction for [u][v] and [v][u].After visting vertex 0,do the same for n-2 non visited vertices.

what is the purpose of ” from[i]=v ” ?

Can’t understand the algorithm behind this code properly….Please explain what are we storing in visited,distance and from arrays….An allover better explanation will definitely help very much.

Can u plz add example of prims algorithmas similar to krushkal algo. for the easy understanding

Why is it necessary for every student to learn this algorithm when its already available on internet????

Why?

Exactly!!!!!!

agree

how does it checks wheather there is formation of cycle in spanning tree ?

This is not the code for Prims, for prims it is necessary to be able to pick the node from where you start. Also Prims doesnt need the union find datastructure which seems you implemented with the part where you set the parent from G[0][0] to G[0][v] after first initialization. This is just another implementation of Kruskal where you start with the lowest edge. This may cause some confusion.