Spaces:
Sleeping
Sleeping
Commit
·
87b01f5
1
Parent(s):
b2a1451
Update app.py
Browse files
app.py
CHANGED
@@ -89,63 +89,63 @@ def read_cells(cell,model):
|
|
89 |
|
90 |
#This function finds the next box to solve
|
91 |
|
92 |
-
def
|
93 |
-
for
|
94 |
-
for
|
95 |
-
if
|
96 |
-
|
97 |
-
return
|
98 |
|
99 |
#Function to fill in the possible values by evaluating rows collumns and smaller cells
|
100 |
|
101 |
-
def
|
102 |
-
#
|
103 |
-
for i in range
|
104 |
-
if
|
105 |
-
|
106 |
-
|
107 |
-
|
|
|
|
|
|
|
108 |
return False
|
109 |
|
110 |
-
|
111 |
-
|
112 |
-
|
113 |
-
|
114 |
-
|
|
|
|
|
|
|
|
|
115 |
return False
|
|
|
116 |
return True
|
117 |
|
118 |
-
#Recursion function to loop over untill a valid answer is found.
|
119 |
|
120 |
-
|
121 |
-
|
122 |
-
|
|
|
|
|
|
|
123 |
return True
|
124 |
else:
|
125 |
-
row,
|
126 |
-
|
127 |
-
|
128 |
-
|
129 |
-
|
130 |
-
|
131 |
-
|
132 |
-
|
133 |
-
|
|
|
|
|
|
|
|
|
134 |
|
135 |
-
def Solved(quiz):
|
136 |
-
for row in range(9):
|
137 |
-
if row % 3 == 0 and row != 0:
|
138 |
-
print("....................")
|
139 |
-
|
140 |
-
for col in range(9):
|
141 |
-
if col % 3 == 0 and col != 0:
|
142 |
-
print("|", end=" ")
|
143 |
-
|
144 |
-
if col == 8:
|
145 |
-
print(quiz[row][col])
|
146 |
-
else:
|
147 |
-
print(str(quiz[row][col]) + " ", end="")
|
148 |
-
|
149 |
def main():
|
150 |
st.title('Sudoku Solver')
|
151 |
|
|
|
89 |
|
90 |
#This function finds the next box to solve
|
91 |
|
92 |
+
def find_empty(board):
|
93 |
+
for i in range(len(board)):
|
94 |
+
for j in range(len(board)):
|
95 |
+
if board[i][j] == 0:
|
96 |
+
return i,j
|
97 |
+
return None
|
98 |
|
99 |
#Function to fill in the possible values by evaluating rows collumns and smaller cells
|
100 |
|
101 |
+
def valid(board, num, pos):
|
102 |
+
# check row
|
103 |
+
for i in range(len(board)):
|
104 |
+
if board[pos[0]][i]==num and pos[1]!=i:
|
105 |
+
return False
|
106 |
+
|
107 |
+
|
108 |
+
# check column
|
109 |
+
for i in range(len(board)):
|
110 |
+
if board[i][pos[1]]==num and pos[0]!=i:
|
111 |
return False
|
112 |
|
113 |
+
|
114 |
+
|
115 |
+
# check 3X3 cube
|
116 |
+
box_x=pos[0]//3
|
117 |
+
box_y=pos[1]//3
|
118 |
+
|
119 |
+
for i in range(box_x*3,box_x+3):
|
120 |
+
for j in range(box_y*3,box_y+3):
|
121 |
+
if board[i][j]==num and [i,j]!=pos:
|
122 |
return False
|
123 |
+
|
124 |
return True
|
125 |
|
|
|
126 |
|
127 |
+
|
128 |
+
#function to loop over untill a valid answer is found.
|
129 |
+
|
130 |
+
def solve(board):
|
131 |
+
find=find_empty(board)
|
132 |
+
if not find:
|
133 |
return True
|
134 |
else:
|
135 |
+
row,col=find
|
136 |
+
|
137 |
+
|
138 |
+
for i in range(1,10):
|
139 |
+
if valid(board,i,[row,col]):
|
140 |
+
board[row][col]=i
|
141 |
+
|
142 |
+
if solve(board):
|
143 |
+
return True
|
144 |
+
|
145 |
+
board[row][col]=0
|
146 |
+
return False
|
147 |
+
|
148 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
149 |
def main():
|
150 |
st.title('Sudoku Solver')
|
151 |
|