-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathNAllQueen.py
72 lines (67 loc) · 2.34 KB
/
NAllQueen.py
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
'''
This is to find all arrangements of queens
comments start with #
debugging lines commentd with ###, uncommnt these to trace
'''
N=4
mcount = 0
loopc = 0
solCount = 0
def printBoard(board):
for i in range(N):
for j in range(N):
print(board[i][j], end=' ')
print()
def isSafe(pos,q,row,col):
###print(f'Checking safty of queen {row} to place at ({row},{col}) w.r.t queen {q} ')
###print(f'Positions of queen {q} - ',pos[q])
if(pos[q][0] == row
or pos[q][1] == col
or pos[q][0] + pos[q][1] == row + col
or pos[q][0] - pos[q][1] == row - col):
###print('returning False\n')
return False
###print('returning true\n')
return True
def solveNQutil(board, row, pos):
global mcount,loopc,solCount
mcount+=1;
if row == N:
# if its th last row all queens are placed,print positions and solutions
#return True
solCount +=1
print(f'Arrangement {solCount}')
print('--------------')
printBoard(board)
print('Positions - ',pos)
print()
# iterate each column for the row to see if we can find a safe position,
#if safe position found recusively call solveNQUtil for placing another queen
#if safe not found check for next colum, if safe not found for all columns backtrack
for col in range(N):
loopc+=1
foundSafe = True
for q in range(row):
loopc +=1
if(not isSafe(pos,q,row,col)):
foundSafe = False
break
###print(foundSafe)
if(foundSafe) :
###print(f'found Safe position for queen {row} at {row},{col}')
pos[row][0] = row
pos[row][1] = col
board[row][col] = 1
###print(f'calling solveNQ for Queen - {row+1}\n')
solveNQutil(board,row+1,pos)
###print(f'Did not find a place for queen {row+1} backtracking to adjust queen {row}\'s place')
board[row][col] = 0
#return False
if __name__ == '__main__':
board = [[0 for i in range(N)] for j in range(N)]
pos = [[0 for i in range(2)] for j in range(N)]
solveNQutil(board,0,pos)
if solCount ==0:
print('No Solution')
else: print(f'total of {solCount} solutions exists')
print(f'method count {mcount}, loop count {loopc}')