Upper & Lower Bounds for the Travelling Salesman Problem (Edexcel A Level Further Maths): Revision Note
Finding an Upper Bound using a Minimum Connector
Why do I need to find an upper bound?
There is no efficient algorithm to find the optimal solution for the travelling salesman problem
An upper and lower bound for the solution to the problem can be found
The optimal solution (the shortest route) will lie within these bounds
The aim is to find the minimum value for the upper bound to reduce the size of interval between the upper and lower bounds
How do I find the upper bound?
You can find an upper bound for the practical travelling salesman problem using the minimum spanning tree of a network
STEP 1 Find the minimum spanning tree for the network using either Prim's or Kruskal's algorithm
If you have the table of least distances - use Prim's algorithm
If you have the graph only - use Kruskal's algorithm
STEP 2 Double the weight of the minimum spanning tree
Each vertex can therefore definitely be visited and the starting vertex returned to
STEP 3 Reduce the weight of the upper bound by finding shortcuts
Use some of the edges that are not included in the minimum spanning tree to reduce the weight of the upper bound
Worked Example
The network below contains six vertices representing villages and the edges (roads) that connect them. The weighting of the edges represents the time, in minutes, that it takes to walk along a particular road between two villages.
data:image/s3,"s3://crabby-images/ecb1c/ecb1cd661d70ed2a0eab943638107492b7e9e528" alt="3-10-6-ib-ai-hl-bounds-for-travelling-salesman-problem-we-1"
a) Find an initial upper bound for the travelling salesman problem.
STEP 1
The question contains the graph but you have not been asked to find the table of least distances, so apply Kruskal's algorithm to find the minimum spanning tree of the network
List the edges in order of increasing weight
CD (5)
CE (6)
AC (7)
EF (8)
BF (9)
DE (10)
AD (11)
BC (13)
BE (13)
AB (14)
DF (20)
Add the edge of least weight (CD), then the next edge of least weight (CE) Repeat adding the next edge of least weight each time provided it does not create a cycle until all vertices are connected
Edges added in the order: CD (5), CE (6), AC (7), EF (8), BF (9)
data:image/s3,"s3://crabby-images/1584c/1584c0f42c27de385cc1c89644d5f973bb1e9606" alt="WdntKlV2_mst"
STEP 2
Find the weight of the minimum spanning tree
5 + 6 + 7 + 8 + 9 = 35
Double the weight of the minimum spanning tree to find the initial upper bound of the solution
35 x 2 = 70
Initial upper bound = 70 minutes
b) Show that the initial upper bound can be reduced to 54 by finding one shortcut.
STEP 3
Identify which edges could be used to replace repeated edges in the minimum spanning tree
Single edge: AB (14)
Repeated pathway: AC + CE + EF + FB (30)
Subtract the weight of the single edge from the repeated pathway to calculate the weight saved by using the short cut
30 - 14 = 16
Subtract the weight saving from the initial upper bound
70 - 16 = 54
Improved upper bound = 54 minutes
This can also be seen as 70 - 30 + 14 = 54 (subtract the 'repeated pathway', then add the 'shortcut')
Finding a Lower Bound using a Minimum Connector
Why do I need to find the lower bound?
There is no efficient algorithm to find the optimal solution for the travelling salesman problem
An upper and lower bound for the solution to the problem can be found
The optimal solution (the shortest route) will lie within these bounds
The aim is to find the maximum value for the lower bound to reduce the size of interval between the upper and lower bounds
An optimal solution is found if
the lower bound gives a Hamiltonian cycle
the lower bound has the same value as the upper bound
How do I find the lower bound?
You can find a lower bound for the classical travelling salesman problem using the minimum spanning tree of a network
To find a solution for the practical travelling salesman problem you need to apply the steps of the algorithm below to a table of least distances
STEP 1
Remove a vertex and all of its associated edges from the networkSTEP 2
Find the minimum spanning tree for the remaining network and write down its total weightThis spanning tree is known as the residual minimum spanning tree (RMST)
STEP 3
Identify the two shortest individual edges that can connect the missing vertex to the residual minimum spanning tree Calculate the sum of the total weight of the residual minimal spanning tree and the two connecting edgesSTEP 4
Repeat Steps 1 to 3 for each vertex in the networkSTEP 5
When the network has been tested for each missing vertex, identify the maximum valueThis maximum value is the greatest possible lower bound
In many problems Steps 4 and 5 will not be required as a question will dictate which vertex to delete and there will be no need to do them all
This method may be referred to as the deleted vertex method
Worked Example
The table below contains six vertices representing villages and the roads that connect them. The weighting of the edges represents the time in minutes that it takes to walk along a particular road between two villages.
| A | B | C | D | E | F |
A | - | 14 | 7 | 11 | 13 | 21 |
B | 14 | - | 13 | 18 | 13 | 9 |
C | 7 | 13 | - | 5 | 6 | 14 |
D | 11 | 18 | 5 | - | 10 | 18 |
E | 13 | 13 | 6 | 10 | - | 8 |
F | 21 | 9 | 14 | 18 | 8 | - |
a) By deleting vertex A and using Prim’s algorithm, find a lower bound for the time taken to start at village A, visit each of the other villages and return to village A
STEP 1
Delete vertex A in the tableSTEP 2
Perform Prim's algorithm on the remaining vertices in the table
data:image/s3,"s3://crabby-images/1e378/1e3786685908578fb9f1b6d1f4322af72dc663cb" alt="table-1"
Edges added in the order: BF (9), EF (8), CE (6), CD (5)
Total weight of the residual minimum spanning tree = 9 + 8 + 6 + 5 = 28
STEP 3
Identify the two shortest edges that connect A to the minimum spanning tree
AC (7), AD (11)
Add together the total weight of the minimum spanning tree and the weights of the two shortest lengths connecting it to A
28 + 7 + 11 = 46
Lower bound = 46 minutes
b) Show that by deleting vertex E instead, a higher lower bound can be found.
STEP 1
Delete vertex A in the tableSTEP 2
Perform Prim's algorithm on the remaining vertices in the table
data:image/s3,"s3://crabby-images/23bc0/23bc0c3333a6cdf1ab5dab1a852adf71650a0eed" alt="delete-vertex-e"
Edges added in the order: AC (7), CD (5), BD/DF (18), BF (9)
Total weight of the residual minimum spanning tree = 7 + 5 + 18 + 9 = 39
STEP 3
Identify the two shortest edges that connect E to the minimum spanning tree
CE (6), EF (8)
Add together the total weight of the minimum spanning tree and the weights of the two shortest lengths connecting it to E
39 + 6 + 8 = 53
Lower bound = 53 minutes
This is a higher lower bound than found when vertex A was deleted (46 minutes)
Nearest Neighbour Algorithm
What is the nearest neighbour algorithm?
For a complete network with at least 3 vertices, performing the nearest neighbour algorithm will generate a low (but not necessarily least) weight Hamiltonian cycle
This low weight cycle can be considered the upper bound
The best upper bound is the upper bound with the smallest value
The nearest neighbour algorithm can only be used on a graph that is complete and satisfies the triangle inequality
If need be the table of least distances should be found first
What are the steps of the nearest neighbour algorithm?
STEP 1
Choose a starting vertex
STEP 2
Select the edge of least weight from the current vertex to an adjacent unvisited vertexif there is more than one edge of least weight pick one at random
move to this vertex (column in matrix form)
if this is the final vertex to be visited go to Step 3
otherwise disregard (cross out in matrix form) any edges that go to vertices already visited and repeat Step 2
STEP 3
Add a final edge to return to the starting vertex
STEP 4
Find the weight of the resulting Hamiltonian cycle to produce an upper bound for the travelling salesman problem
STEP 5
Repeat Steps 1 to 4 starting with a different vertex in the network
When the network has been tested for each vertex as the starting vertex, identify the minimum value
This minimum value is the least possible lower bound
In many problems Step 5 will not be required as a question will dictate which vertex to start at and there will be no requirement to repeat with all vertices as the starting vertex
Examiner Tips and Tricks
Be careful not to muddle up the nearest neighbour algorithm with Prim's algorithm just because they can both be performed on tables - this is a common mistake!
Questions may ask you to explain the difference between the two algorithms
The nearest neighbour algorithm selects the nearest vertex adjacent to the current vertex
Prim's algorithm selects the nearest vertex adjacent to any vertex already visited
Worked Example
The table below contains six vertices representing villages and the roads that connect them. The weighting of the edges represents the time in minutes that it takes to walk along a particular road between two villages.
| A | B | C | D | E | F |
A | - | 14 | 7 | 11 | 13 | 21 |
B | 14 | - | 13 | 18 | 13 | 9 |
C | 7 | 13 | - | 5 | 6 | 14 |
D | 11 | 18 | 5 | - | 10 | 18 |
E | 13 | 13 | 6 | 10 | - | 8 |
F | 21 | 9 | 14 | 18 | 8 | - |
Starting at village A, use the nearest neighbour algorithm to find the upper bound of the time it would take to visit each village and return to village A.
STEP 1
Start at vertex A (column A)STEP 2
Select the edge of least weight in column A (AC) and write it down
data:image/s3,"s3://crabby-images/83bbd/83bbdf225aefc51081f28bd1cc1e3f3bfec24295" alt="~8028F-4_table-1"
AC (7)
Move to vertex/column C
C is not the final vertex to be visited
Disregard (cross out) the edge (value) in column C that would connect C to A as vertex A has already been visited
Repeat Step 2
STEP 2
Select the edge of least weight (from those remaining) in column C (CD) and write it down
data:image/s3,"s3://crabby-images/a169d/a169d2e868b3da4f8137a3809236ab0fdea75411" alt="0IaJRg_O_table-2"
AC (7), CD (5)
Move to column D
D is not the final vertex
Cross out the values for the vertices already visited (A and C)
Repeat Step 2
STEP 2
Select the edge of least weight (from the remaining) in column D (DE) and write it down
data:image/s3,"s3://crabby-images/3e613/3e6130283b358df9970542e179442fe614098aca" alt="table-3"
AC (7), CD (5), DE (10)
Move to column E
E is not the final vertex
Cross out the values for the vertices already visited (A, C and D)
Repeat Step 2
STEP 2
Select the edge of least weight (from the remaining values) in column E (EF) and write it down
data:image/s3,"s3://crabby-images/0a1d7/0a1d7526942fc2c088b1e7d175ff3f1232761533" alt="table-4"
AC (7), CD (5), DE (10), EF (8)
Move to vertex F
F is not the final vertex
Cross out the values for the vertices already visited (A, C, D and E)
Repeat Step 2
STEP 2
Select the edge of least weight (from the remaining values) in column F (BF) and write it down
data:image/s3,"s3://crabby-images/bc97f/bc97fb4598cf004b1c7b120bbe758ff040a3fa61" alt="table-5"
AC (7), CD (5), DE (10), EF (8), BF (9)
Move to vertex B
B is the final vertex to be visited
Go to Step 3
STEP 3
Choose the final edge (value) to get back from the last vertex (B) to the starting vertex (A)
data:image/s3,"s3://crabby-images/56af8/56af8d41e5ef2431b0a79ad9b09d218bb46a78fd" alt="table-6"
AC (7), CD (5), DE (10), EF (8), BF (9), AB (14)
Hamiltonian cycle: ACDEFBA
STEP 4
Find the weight of the Hamiltonian cycle by adding together the weights of the edges forming it
Total weight = 7 + 5 + 10 + 8 + 9 + 14 = 53
This is an upper bound for the travelling salesman problem
Upper bound = 53 minutes
You've read 0 of your 5 free revision notes this week
Sign up now. It’s free!
Did this page help you?