-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday5.dart
84 lines (71 loc) · 2.11 KB
/
day5.dart
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
import 'package:tuple/tuple.dart';
import './utils.dart';
class Vec {
int x0;
int y0;
int x1;
int y1;
Vec(this.x0, this.y0, this.x1, this.y1);
@override
String toString() {
return 'Vec($x0,$y0) -> ($x1,$y1)';
}
bool isDiagonal() {
return this.x0 != this.x1 && this.y0 != this.y1;
}
List<Tuple2<int, int>> getPoints() {
List<Tuple2<int, int>> points = [];
int startX = this.x0 < this.x1 ? this.x0 : this.x1;
int endX = startX == this.x0 ? this.x1 : this.x0;
if (this.isDiagonal()) {
// get only points on diagonal, not a zig-zag!
int startY = startX == this.x0 ? this.y0 : this.y1;
int endY = startY == this.y0 ? this.y1 : this.y0;
int signY = startY < endY ? 1 : -1;
int y = startY;
for (int x = startX; x <= endX; x++) {
points.add(Tuple2(x, y));
y += 1 * signY;
}
} else {
int startY = this.y0 < this.y1 ? this.y0 : this.y1;
int endY = startY == this.y0 ? this.y1 : this.y0;
for (int x = startX; x <= endX; x++) {
for (int y = startY; y <= endY; y++) {
points.add(Tuple2(x, y));
}
}
}
return points;
}
}
int solve(List<String> rows) {
List<Vec> lines = rows.map((String row) {
List<String> ends = row.trim().split(' -> ');
List<int> start = ends[0].split(',').map(int.parse).toList();
List<int> end = ends[1].split(',').map(int.parse).toList();
return Vec(start[0], start[1], end[0], end[1]);
}).toList();
// first part lines input
// List<Vec> filteredLines = lines.where((v) => !v.isDiagonal()).toList();
// second part lines input
List<Vec> filteredLines = lines;
Set<Tuple2<int, int>> points = Set();
Set<Tuple2<int, int>> overlapped = Set();
int overlaps = 0;
filteredLines.forEach((line) {
line.getPoints().forEach((point) {
if (points.contains(point) && !overlapped.contains(point)) {
overlaps++;
overlapped.add(point);
}
points.add(point);
});
});
return overlaps;
}
void main() async {
List<String> lines = await readlines('day5.txt');
int result = solve(lines);
print(result);
}