You are on page 1of 5

What is Best First Search?

If we consider searching as a form of traversal in a graph, an uninformed search algorithm would blindly
traverse to the next node in a given manner without considering the cost associated with that step. An informed
search, like Best first search, on the other hand would use an evaluation function to decide which among the
various available nodes is the most promising (or ‘BEST’) before traversing to that node. 

The Best first search uses the concept of a Priority queue and heuristic search. To search the graph space, the
BFS method uses two lists for tracking the traversal. An ‘Open’ list which keeps track of the current
‘immediate’ nodes available for traversal and ‘CLOSED’ list that keeps track of the nodes already traversed. 

Best First Search Algorithm


1. Create 2 empty lists: OPEN and CLOSED
2. Start from the initial node (say N) and put it in the ‘ordered’ OPEN list
3. Repeat the next steps until GOAL node is reached
1. If OPEN list is empty, then EXIT the loop returning ‘False’
2. Select the first/top node (say N) in the OPEN list and move it to the CLOSED list. Also capture
the information of the parent node
3. If N is a GOAL node, then move the node to the Closed list and exit the loop returning ‘True’.
The solution can be found by backtracking the path
4. If N is not the GOAL node, expand node N to generate the ‘immediate’ next nodes linked to
node N and add all those to the OPEN list
5. Reorder the nodes in the OPEN list in ascending order according to an evaluation function f(n)

This algorithm will traverse the shortest path first in the queue. The time complexity of the algorithm is given
by O(n*logn) .

Variants of Best First Search


The two variants of Best First Search are Greedy Best First Search and A* Best First Search. The Greedy
BFS algorithm selects the path which appears to be the best, it can be known as the combination of depth-first
search and breadth-first search. Greedy BFS makes use of Heuristic function and search and allows us to take
advantages of both algorithms.

The only difference between Greedy BFS and A* BFS is in the evaluation function. For Greedy BFS the
evaluation function is f(n) = h(n) while for A* the evaluation function is f(n) = g(n) + h(n).

Essentially, since A* is more optimal of the two approaches as it also takes into consideration the total distance
travelled so far i.e. g(n).

Best First Search Example


Let’s have a look at the graph below and try to implement both Greedy BFS and A* algorithms step by step
using the two list, OPEN and CLOSED.

g(n) Path Distance

h(n) Estimate to Goal


f(n) Combined Hueristics i.e. g(n) + h(n)
Even though you would find that both Greedy BFS and A* algorithms find the path equally efficiently, number
of steps, you may notice that the A* algorithm is able to come up with is a more optimal path than Greedy BFS.
So in summary, both Greedy BFS and A* are Best first searches but Greedy BFS is neither complete, nor
optimal whereas A* is both complete and optimal. However, A* uses more memory than Greedy BFS, but it
guarantees that the path found is optimal.

Advantages and Disadvantages of Best First Search

Advantages:
1. Can switch between BFS and DFS, thus gaining the advantages of both.
2. More efficient when compared to DFS.

Disadvantages:
1. Chances of getting stuck in a loop are higher.

You might also like