generated from github/codespaces-jupyter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsimple_sudoku.py
112 lines (87 loc) · 2.65 KB
/
simple_sudoku.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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
# This file contains a simple standalone sudoku solver
# deliberately it is without libraries and all self contained
# this is a depth-first backtracking search algorithm
# it searches on first empty cell and tries first unique number in cell
#
# Example is take from:
# https://saturncloud.io/blog/python-sudoku-wave-function-collapse-algorithm-implementation/
#
# simply use: python simple_sudoku.py to run this program
#
iterations = 0
def display_grid(grid):
'''Display the grid'''
for i in range(9):
if i in [3, 6]:
print('------+-------+------')
print_line = ""
for j in range(9):
print_line += str(grid[i][j])
print_line += " | " if j in [2, 5] else " "
print(print_line)
def count_nonzero(grid):
n = 0
for row in range(9):
for col in range(9):
if grid[row][col] != 0:
n += 1
return n
def is_complete(grid):
for row in range(9):
for col in range(9):
if grid[row][col] == 0:
return False
return True
def find_empty_cell(grid):
for row in range(9):
for col in range(9):
if grid[row][col] == 0:
return row, col
return None, None
def is_valid(grid, row, col, num):
for i in range(9):
if grid[row][i] == num or grid[i][col] == num:
return False
start_row = (row // 3) * 3
start_col = (col // 3) * 3
for i in range(start_row, start_row + 3):
for j in range(start_col, start_col + 3):
if grid[i][j] == num:
return False
return True
def solve_sudoku(grid):
global iterations
iterations += 1
if is_complete(grid):
return True
row, col = find_empty_cell(grid)
for num in range(1, 10):
if is_valid(grid, row, col, num):
grid[row][col] = num
if solve_sudoku(grid):
return True
grid[row][col] = 0
return False
# Parool Dinsdag 19 sept ****
sudoku_grid = [
[0, 6, 0, 0, 0, 0, 1, 9, 0],
[0, 0, 2, 6, 1, 0, 0, 0, 4],
[7, 0, 1, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 7, 0, 0, 1, 0],
[0, 0, 6, 0, 8, 3, 0, 0, 0],
[5, 4, 0, 0, 6, 0, 0, 0, 3],
[0, 8, 0, 0, 2, 7, 0, 3, 9],
[0, 0, 0, 4, 0, 0, 0, 7, 8],
[0, 0, 0, 0, 0, 0, 4, 0, 0]
]
def main(grid):
print("Fill before rate: {0:d}".format(count_nonzero(grid)))
res = solve_sudoku(grid)
fr = count_nonzero(grid)
frp = fr / 81 * 100.0
print("Fill after rate: {0:d} ({1:0.0f}%)".format(fr, frp))
print("Iterations: {0:d}".format(iterations))
display_grid(grid)
return res
if __name__ == '__main__':
main(sudoku_grid)