-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathPercolation.java
83 lines (71 loc) · 2.03 KB
/
Percolation.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
public class Percolation {
private int N;
private WeightedQuickUnionUF uf;
private boolean[] isopen;
public Percolation(int N) {
if (N <= 0)
throw new IllegalArgumentException();
this.N = N;
// Two additiional sites for top and bottom
uf = new WeightedQuickUnionUF(N * N + 2);
isopen = new boolean[N * N];
for (int i = 0; i < N * N; i++) {
isopen[i] = false;
}
}
public void open(int i, int j) {
validate(i, j);
isopen[xyTo1D(i, j)] = true;
if (i > 1) {
if (isOpen(i - 1, j)) {
uf.union(xyTo1D(i, j), xyTo1D(i - 1, j));
}
}
if (i < N) {
if (isOpen(i + 1, j)) {
uf.union(xyTo1D(i, j), xyTo1D(i + 1, j));
}
}
if (j > 1) {
if (isOpen(i, j - 1)) {
uf.union(xyTo1D(i, j), xyTo1D(i, j - 1));
}
}
if (j < N) {
if (isOpen(i, j + 1)) {
uf.union(xyTo1D(i, j), xyTo1D(i, j + 1));
}
}
// link to the top site
if (i == 1) {
uf.union(N * N, xyTo1D(i, j));
}
// if (i == N) {
// uf.union(N * N + 1, xyTo1D(i, j));
// }
}
public boolean isOpen(int i, int j) {
validate(i, j);
return isopen[xyTo1D(i, j)];
}
public boolean isFull(int i, int j) {
validate(i, j);
return uf.connected(N * N, xyTo1D(i, j));
}
public boolean percolates() {
// return uf.connected(N * N, N * N + 1);
for (int i = N * N - 1; i >= N * N - N; i--) {
if (isopen[i] && uf.connected(N * N, i)) return true;
}
return false;
}
private int xyTo1D(int x, int y) {
validate(x, y);
int idx = (x - 1) * N + (y - 1);
return idx;
}
private void validate(int i, int j) {
if (i <= 0 || i > N || j <= 0 || j > N)
throw new IndexOutOfBoundsException();
}
}