Prim's Algorithm (Edexcel International A Level Maths): Revision Note
Introduction to Prim's Algorithm
What is Prim's algorithm?
Prim's algorithm is another method of finding a minimum spanning tree in a network
It can be used when the information for a network is given as a graph or in a matrix
Prim's Algorithm using Edges & Vertices
What are the steps in Prim’s Algorithm when using a graph?
Prim’s algorithm adds edges from vertices that are already connected to the tree
Cycles are avoided by only adding edges that do not connect two vertices already in the tree
STEP 1
Start at any vertex and choose the edge of least weight that is connected to it
STEP 2
Choose the edge of least weight that is connected to any of the vertices already in the tree
Ensure that it does not connect to a second vertex that is already in the treeIf there is a choice of edges of equal weight, either can be selected
STEP 3
Repeat STEP 2 until all of the vertices are added to the tree
STEP 4
List the edges in the minimum spanning tree in the order they were added
Worked Example
Consider the network, G, below.
data:image/s3,"s3://crabby-images/ab3e6/ab3e6d670db74bf31bd768e4f99d1b68c41faabc" alt="3-10-3-ib-ai-hl-minimum-spanning-trees-we-2"
a) Using Prim’s algorithm, find a minimum spanning tree for G.
STEP 1
Select a starting vertex (we will use A here, but you could start at any vertex)
Choose the edge of least weight connected to it
data:image/s3,"s3://crabby-images/70638/706380f6dfefa8d6822ac27ea98ab913ed20c0e3" alt="prim-1"
AB (15)
STEP 2
Select the next edge of least weight that is connected to either of the vertices already in the tree
data:image/s3,"s3://crabby-images/eed7d/eed7d44ef01751d3480daede22e72bd15a2a9fb0" alt="tYwxOSlL_picture-2"
AB (15), BC (13)
STEP 3
Continue to select the edge of least weight that is connected to any of the other vertices that are already in the tree
data:image/s3,"s3://crabby-images/a75ee/a75ee00aef9ece4d569c7ae6603f094d7ba5c599" alt="prim-2"
AB (15), BC (13), CE (12)
STEP 4
Remember to record the order in which the edges were added
data:image/s3,"s3://crabby-images/6da2f/6da2f294ee139f88ea6106a4cd6a80e090fb1776" alt="prim-3"
Edges added in the order: AB (15), BC (13), CE (12), BD (17)
b) State the total weight of the minimum spanning tree.
Add up the weight of the edges in the minimum spanning tree
15 + 13 + 12 + 17 = 57
Total weight = 57
Prim's Algorithm using a Matrix
How do you apply Prim’s algorithm to a matrix?
A minimum spanning tree can be constructed from a distance matrix
By looking at the relevant rows in the distance matrix
STEP 1
Select any vertex to start from
Cross out the values in the column associated with that vertex
Label the row associated with the vertex 1
STEP 2
Circle the lowest value in any cell along that row
Add the corresponding edge to the tree
Cross out the remaining values in the column of the cell that you have circled
STEP 3
Label the row associated with the same vertex as the column in STEP 2 with the next number
STEP 4
Circle the lowest value in any cell along any of the rows that have been labelled
Add the corresponding edge to the tree
Cross out the remaining values in the column of the cell that you have circled
STEP 5
Repeat STEPS 3 and 4 until all vertices have been added to the tree
Some versions of Prim's algorithm using a matrix will cross out rows and label columns
Either version will work to find a minimum spanning tree
Examiner Tips and Tricks
Look out for questions that ask you to minimise the cost or length etc. from a network
They are implying that they want you to find a minimum spanning tree
Be careful not to confuse Prim's algorithm with the Nearest Neighbour algorithm
Worked Example
The adjacency matrix of a network, is shown below.
| A | B | C | D | E |
A | - | 15 | 22 | 18 | 25 |
B | 15 | - | 13 | 17 | 24 |
C | 22 | 13 | - | 30 | 12 |
D | 18 | 17 | 30 | - | 21 |
E | 25 | 24 | 12 | 21 | - |
a) Starting from vertex A, use Prim’s algorithm on the table to find and draw a minimum spanning tree for the network. Show each step of the process clearly.
STEP 1
We'll start here with vertex A, although you could start with any vertex
Label the row for vertex A as '1'
Cross out the values in column A
data:image/s3,"s3://crabby-images/818e7/818e7720fd1a7763dc15f974b5385691492d8ee2" alt="prims-1"
STEP 2
Circle the edge of least weight in row 1 and record which edge it is (here it is B)
Delete the remaining values in column B
data:image/s3,"s3://crabby-images/ab3c4/ab3c47d735478b91829f128bbf98a2db83cf8dfb" alt="prims-2"
AB (15)
STEP 3
Label the row for vertex B as '2'
STEP 4
Circle the edge of least weight out of all the entries in rows 1 and 2, remembering to record the edge
Cross out the remaining values in the column of that circled edge
data:image/s3,"s3://crabby-images/4ef88/4ef88b65958dcdb452b132d145850521f41969c9" alt="prims-3"
AB (15), BC (13)
STEP 5
Repeat Steps 3 and 4 until all vertices are added
STEP 3
Label the row for vertex C as '3'
STEP 4
Circle the edge of least weight in rows 1 to 3, remembering to record the edge
Delete the remaining values in column E
data:image/s3,"s3://crabby-images/025f8/025f8123b1730dab4044d243e0fc0c8a90b4a7f2" alt="prims-4"
AB (15), BC (13), CE (12)
STEP 3
Label the row for vertex E as '4'
STEP 4
Circle the edge of least weight in rows 1 to 4, remembering to record the edge
Delete the remaining values in column D
data:image/s3,"s3://crabby-images/f2080/f2080427736a813c243e3151efbe8fd44a925398" alt="prims-5"
AB (15), BC (13), CE (12), BD (17)
All vertices have been selected
You should have a list of the order in which the edges were selected
data:image/s3,"s3://crabby-images/6da2f/6da2f294ee139f88ea6106a4cd6a80e090fb1776" alt="prim-3"
Edges added in the order: AB (15), BC (13), CE (12), BD (17)
b) State the total weight of the minimum spanning tree.
Add up the weights of the edges in the minimum spanning tree.
15 + 13 + 12 + 17 = 57
Total weight = 57
You've read 0 of your 5 free revision notes this week
Sign up now. It’s free!
Did this page help you?