KEMBAR78
AI Lab Assignment 4 | PDF | Applied Mathematics | Mathematical Analysis
0% found this document useful (0 votes)
61 views4 pages

AI Lab Assignment 4

Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
61 views4 pages

AI Lab Assignment 4

Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 4

lO

Mo

AIAI LabLab ManualManual


ExperimentExperiment NoNo 44
lOMoARcPSD|20886596

Experiment No.: 04

Aim:- Implement a solution for a Constraint Satisfaction Problem using Branch and Bound and
Backtracking for n-queens problem or a graph coloring problem.

Operating System recommended :- 64-bit Windows OS and Linux

Programming tools recommended: -

Theory:-

8 Queens Problem using Branch and Bound


The N-Queens problem is a puzzle of placing exactly N queens on an NxN chessboard, such that no two
queens can attack each other in that configuration. Thus, no two queens can lie in the same row,column
or diagonal.

The branch and bound solution is somehow different, it generates a partial solution until it figures
that there's no point going deeper as we would ultimately lead to a dead end.

In the backtracking approach, we maintain an 8x8 binary matrix for keeping track of safe cells (by
eliminating the unsafe cells, those that are likely to be attacked) and update it each time we place a
new queen. However, it required O(n^2) time to check safe cell and update the queen.

In the 8 queens problem, we ensure the following:

1. no two queens share a row


2. no two queens share a column
3. no two queens share the same left diagnol
4. no two queens share the same right diagnol

we already ensure that the queens do not share the same column by the way we fill out our auxiliary
matrix (column by column). Hence, only the left out 3 conditions are left out to be satisfied.

Applying the branch and bound approach :


The branch and bound approach suggets that we create a partial solution and use it to ascertain whether we
need to continue in a particular direction or not. For this problem we create 3 arrays to check for conditions
1,3 and 4. The boolean arrays tell which rows and diagonals are already occupied.
To achieve this, we need a numbering system to specify which queen is placed.

The indexes on these arrays would help us know which queen we are analysing.

Preprocessing - create two NxN matrices, one for top-left to bottom- right diagnol, and other for top-right
to bottom-left diagnol. We need to fill these in such a way that two queens sharing same top- left_bottom-
right diagnol will have same value in slashDiagonal and two queens sharing same top-right_bottom-left
diagnol will have same value in backSlashDiagnol.

slashDiagnol(row)(col) = row + col backSlashDiagnol(row)(col) = row - col + (N-1) { N = 8 }

{ we added (N-1) as we do not need negative values in backSlashDiagnol }


lOMoARcPSD|20886596

For placing a queen i on row j, check the following :

1. whether row 'j' is used or not


2. whether slashDiagnol 'i+j' is used or not
3. whether backSlashDiagnol 'i-j+7' is used or not

If the answer to any one of the following is true, we try another location for queen i on row j, mark the
row and diagnols; and recur for queen i+1.

Graph coloring problem’s solution using backtracking algorithm

Graph coloring:
The graph coloring problem is to discover whether the nodes of the graph G can be covered in such a way,
hat no two adjacent nodes have the same color yet only m colors are used. This graph coloring problem is
also known as M- colorability decision problem.

The M – colorability optimization problem deals with the smallest integer m for which the graph G
can be colored. The integer is known as a chromatic number of the graph.

Here, it can also be noticed that if d is the degree of the given graph, then it can be colored with d+ 1 color.

A graph is also known to be planar if and only if it can be drawn in a planar in such a way that no two edges
cross each other. A special case is the 4 - colors problem for planar graphs. The problem is to color the
region in a map in such a way that no two adjacent regions have the same color. Yet only four colors are
needed. This is a problem for which graphs are very useful because a map can be easily transformed into a
graph. Each region of the map becomes the node, and if two regions are adjacent, they are joined by an edge.

Graph coloring problem can also be solved using a state space tree, whereby applying a backtracking
method required results are obtained.

For solving the graph coloring problem, we suppose that the graph is represented by its adjacency
matrix G[ 1:n, 1:n], where, G[ i, j]= 1 if (i, j) is an edge of G, and G[i, j] = 0 otherwise.

The colors are represented by the integers 1, 2, ..., m and the solutions are given by the n-tuple (x1, x2, x3, ...,
xn), where x1 is the color of node i.
lOMoARcPSD|20886596

Algorithm for finding the m - colorings of a graph

Algorithm mcoloring ( k )
// this algorithm is formed using the recursive backtracking
// schema. The graph is represented by its Boolean adjacency
// matrix G [1: n, 1: n]. All assignments of 1, 2, …, m to the
// vertices of the graph such that adjacent vertices are
// assigned distinct are printed. K is the index
// of the next vertex to color.
{
Repeat
{
// generate all legal assignments for x[k], Next value (k); // assign to x[k] a legal color.
If ( x[k] = 0 ) then return; // no new color possible
If (k = n) then // at most m colors have been used to color the n

vertices.
Write (x[1 : n ]);
Else mcoloring (k + 1);
}
Until (false);
}

This algorithm uses the recursive backtracking schema. In this algorithm colors to be assigned are to
determine
from the range (0, m), i.e., m colors are available.

The total time required by the above algorithm is O (nm^n).

Conclusion:
Thus we have implemented n queen problem or a graph coloring problem using Branch and Bound and
Backtracking algorithm.

Prepared By: Prof.Pooja Oza-


Jaiswal

You might also like