-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsolver.c
115 lines (96 loc) · 2.54 KB
/
solver.c
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
113
114
115
#include <stdio.h>
#include <stdlib.h>
#define FALSE 0
#define TRUE !FALSE
int **reader(int *m, int *n);
void free_sudoku(int **sudoku);
void print_sudoku(int m, int n, int **sudoku);
int solve(int m, int n, int **sudoku);
int main() {
int m, n;
int **sudoku = reader(&m, &n);
print_sudoku(m, n, sudoku);
solve(m, n, sudoku);
print_sudoku(m, n, sudoku);
free_sudoku(sudoku);
}
int **reader(int *m_addr, int *n_addr) {
int m, n;
scanf("%d %d", &m, &n);
int **sudoku = malloc(sizeof(int*) * m * n);
int *grid = malloc(sizeof(int) * m * n * m * n);
int i;
for (i = 0; i < m * n; i++) {
sudoku[i] = &(grid[i * m * n]);
}
for (i = 0; i < m * n * m * n; i++) {
scanf("%d", &(grid[i]));
}
*m_addr = m;
*n_addr = n;
return sudoku;
}
void free_sudoku(int **sudoku) {
free(sudoku[0]);
free(sudoku);
}
void print_sudoku(int m, int n, int **sudoku) {
printf("%d %d\n", m, n);
int i, j;
for (i = 0; i < m * n; i++) {
for (j = 0; j < m * n - 1; j++) {
printf("%d ", sudoku[i][j]);
}
printf("%d\n", sudoku[i][j]);
}
}
int solve(int m, int n, int **sudoku) {
int i = 0, j = 0;
while (i < m * n) {
if (sudoku[i][j] == 0) break;
j++;
if (j == m * n) {
j = 0;
i++;
}
}
if (i >= m * n) {
return TRUE;
}
int v;
for (v = 1; v <= m * n; v++) {
int k, valid = TRUE;
for (k = 0; k < m * n; k++) {
// Scan rows and columns for collisions
if ((sudoku[i][k] == v && k != j) ||
(sudoku[k][j] == v && i != k)) {
valid = FALSE;
break;
}
}
if (valid) {
// Scan box for collisions
int bx = (i/m) * m, by = (j/n) * n;
int l;
for (k = 0; valid && k < m; k++) {
if (bx + k == i) continue;
for (l = 0; l < n; l++) {
if (by + l == j) continue;
if (sudoku[bx + k][by + l] == v) {
valid = FALSE;
break;
}
}
}
}
if (valid) {
sudoku[i][j] = v;
if (solve(m, n, sudoku)) {
return TRUE;
}
}
}
// Give up and return
sudoku[i][j] = 0;
return FALSE;
}