-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathDay10.java
64 lines (57 loc) · 1.62 KB
/
Day10.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
package com.sbaars.adventofcode.year21.days;
import com.sbaars.adventofcode.year21.Day2021;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Stack;
public class Day10 extends Day2021 {
public Day10() {
super(10);
}
public static void main(String[] args) throws IOException {
new Day10().printParts();
}
@Override
public Object part1() {
return getScore(false).get(0);
}
@Override
public Object part2() {
List<Long> scores = getScore(true);
return scores.stream().sorted().skip(scores.size() / 2).findFirst().get();
}
private List<Long> getScore(boolean part) {
Map<Character, Character> m = Map.of(')', '(', ']', '[', '>', '<', '}', '{');
Map<Character, Integer> p = part ? Map.of('(', 1, '[', 2, '{', 3, '<', 4) : Map.of(')', 3, ']', 57, '>', 25137, '}', 1197);
var in = dayStrings();
List<Long> scores = new ArrayList<>();
long score1 = 0;
out:
for (String line : in) {
Stack<Character> s = new Stack<>();
for (Character c : line.toCharArray()) {
if (m.containsKey(c)) {
if (!s.isEmpty()) {
Character stackC = s.pop();
if (!m.get(c).equals(stackC)) {
if (!part) score1 += p.get(c);
continue out;
}
}
} else {
s.push(c);
}
}
if (!part) continue;
long score = 0;
while (!s.isEmpty()) {
Character c = s.pop();
score = (score * 5) + p.get(c);
}
scores.add(score);
}
if (!part) return List.of(score1);
return scores;
}
}