-
Notifications
You must be signed in to change notification settings - Fork 81
/
Copy pathSudoku.java
executable file
·99 lines (97 loc) · 1.65 KB
/
Sudoku.java
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
import java.io.*;
class Sudoku
{
static BufferedReader br=new BufferedReader(new InputStreamReader(System.in));
static int a[][]={
{8,0,0, 0,0,0, 0,0,0},
{0,0,3, 6,0,0, 0,0,0},
{0,7,0, 0,9,0, 2,0,0},
{0,5,0, 0,0,7, 0,0,0},
{0,0,0, 0,4,5, 7,0,0},
{0,0,0, 1,0,0, 0,3,0},
{0,0,1, 0,0,0, 0,6,8},
{0,0,8, 5,0,0, 0,1,0},
{0,9,0, 0,0,0, 4,0,0},
};
static int b[][]=a;
static int c=0;
public static void main(String arghh[])throws IOException
{
Sudoku obj=new Sudoku();
generate(a,0,-1);
System.out.println("Total solutions = "+obj.c);
}
static void generate(int [][]a,int x,int y)
{
if(x==8&&y==8)
{
c++;
display(a);
return;
}
else if(x!=8&&y==8)
{
x++;
y=0;
}
else
y++;
for(int i=x;i<9;i++)
{
for(int j=y;j<9;j++)
{
x=0;
y=0;
if(b[i][j]==0)
{
for(int k=1;k<=9;k++)
{
if(checkValidity(a,i,j,k))
{
a[i][j]=k;
generate(a,i,j);
a[i][j]=0;
}
if(k==9&&a[i][j]==0)
return;
}
}
}
}
}
static void display(int [][]a)
{
for(int i=0;i<9;i++)
{
if(i%3==0)
System.out.println("---------------------");
for(int j=0;j<9;j++)
{
if(j%3==0)
System.out.print(" | ");
System.out.print(a[i][j]);
}
System.out.println(" | ");
}
System.out.println("---------------------");
}
static boolean checkValidity(int [][]a,int i,int j,int m)
{
for(int x=0;x<9;x++)
{
if(a[x][j]==m||a[i][x]==m)
return false;
}
int p=i/3;
int q=j/3;
for(int x=3*p;x<3*(p+1);x++)
{
for(int y=3*q;y<3*(q+1);y++)
{
if(a[x][y]==m)
return false;
}
}
return true;
}
}