forked from harsimrans/algorithms
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkruskal.c
90 lines (74 loc) · 1.59 KB
/
kruskal.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
/******************************************
*
* Kruskals algorithm
*
* Harsimran Singh
*
* Finds the cost of min. spanning tree
******************************************/
#include<stdio.h>
//graph (only supporting 10 set of nodes)
int cost[10][10], parent[10]; //depict the set node belongs to
int minCost = 0;
int main()
{
int n;
int i, j;
printf("enter the num of edges: ");
scanf("%d", &n);
for (i = 0 ; i < n; i++)
{
for (j = 0 ; j < n; j++)
{
scanf("%d", &cost[i][j]);
}
}
//seting each node as it`s parent
for (i = 0; i < n; i++)
{
parent[i] = i;
}
int tmp = n-1;
while(tmp--)
{
//traking the minimum edge
int minEdge = 999999999; //arbitrary high value, garuntee to be max
int source, dest;
for (i = 0; i < n; i++)
{
for(j = 0; j < n; j++)
{
if (cost[i][j] < minEdge)
{
minEdge = cost[i][j];
source = i;
dest = j;
}
}
}
//can we add a edge??
//yes if no cycle occurs :)
//check for cycle i.e belong to same parent
int s = parent[source];
int d = parent[dest];
if (s != d) //there is already a path? NO
{
if (s != source)
{
parent[dest] = s;
}
else if (d != dest)
{
parent[source] = d;
}
}
//added the edges
minCost += cost[source][dest];
printf("adding : %d, %d -> %d\n", cost[source][dest], source,dest);
cost[source][dest] = 99999999; //make it so high cannot be covered again
cost[dest][source] = 99999999;
}
printf("min cost: %d\n", minCost);
return 0;
}