-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTest.java
More file actions
39 lines (35 loc) · 1.19 KB
/
Test.java
File metadata and controls
39 lines (35 loc) · 1.19 KB
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
public class Test {
public static void main(String[] args) {
boolean[] start = {true, true, true, false, false};
boolean[] end = {false, false, true, true, true};
boolean[] change = new boolean[start.length];
boolean[] middle = start;
for (int i = 0; i < start.length; i++) {
change[i] = !(start[i] && end[i]);
//System.out.println(change[i]);
}
while(!ArrayEqual(middle, end)) {
for (int i = 0; i < middle.length; i++) {
if (i == 0 && change[i] && middle[i] != middle[i + 1]) switcheroo(middle, i);
else if (i == (middle.length - 1) && change[i] && middle[i] != middle[i - 1]) switcheroo(middle, i);
else if (change[i] && (middle[i] != middle[i + 1] || middle[i] != middle[i - 1])) switcheroo(middle, i);
System.out.println(Arrays.toString(middle));
}
}
}
public boolean ArrayEqual(boolean[] a, boolean[] b) {
if (a.length != b.length) return false;
for (int i = 0; i < a.length; i++) {
if (a[i] != b[i]) return false;
}
return true;
}
public void switcheroo(boolean[] a, int i) {
if (a[i]) {
a[i] = false;
return;
} else if (!a[i]) {
a[i] = true;
}
}
}