summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--3/input323
-rw-r--r--3/part1.c35
-rw-r--r--3/part2.c39
3 files changed, 397 insertions, 0 deletions
diff --git a/3/input b/3/input
new file mode 100644
index 0000000..6e5de58
--- /dev/null
+++ b/3/input
@@ -0,0 +1,323 @@
+...........#..#.#.###....#.....
+...#..#...........#.#...#......
+#.....#..#........#...#..##....
+..#...##.#.....#.............#.
+#.#..#......#.....#....#.......
+.....#......#..#....#.....#....
+.......#.#..............#......
+.....#...#..........##...#.....
+...#....#.#...#.#........#...#.
+..#.........###.......##...##..
+.#....#...........#........#..#
+..#.............##.............
+..#.##.#....#................#.
+.....##.#.......#....#...#.....
+......#.#....##................
+..#..........###..#..#.#..#....
+....#..............#....##..#.#
+.#.........#.#....#.#.#....#...
+..#.....#......##.#....#.......
+..#.#....#..#.#...##....###....
+...#......##...#........#.#..#.
+.##.#.......##....#............
+...##..#.#............#...#.#..
+.##...##.#..#..................
+..#......##......#......##.....
+.....##...#..#...#.........#...
+.##.#.....#..#..#.##....##....#
+..#.#......#.......##..........
+......................#......##
+##.#...#.................#.#.#.
+......#.#..........#.....##.#..
+#.#......#.....#...........#...
+.....#...#.......#..#..#.#...#.
+...........#......#.#...#......
+....##...##...........#......#.
+.........#.##..................
+......#...#....#......##.##...#
+......#...#.#########......#...
+.......#.#...#.......#..#......
+............#...#...#.###...##.
+...........#..........#...#....
+...#..#.#................#.#..#
+..#....#.....#.............#.#.
+....##......#........#....#....
+........##...............#....#
+........#..#...#..............#
+...#....#.#...#..#...#....#.#.#
+.........#.......#....##.......
+#.##..............#.#........##
+......................###......
+.........#....##..##....#.#.#..
+.#...##.#.#...#....##..#.....#.
+....................#.#......#.
+.#..#.......................#..
+..#..#.............#..#....#...
+...#...#..#...#...#.#..#.##....
+........#....#...#....#........
+.#.....#........#.........#...#
+...#......#..#..#..####..#.....
+#....#..............#.##.......
+.#....#.............##...#.....
+....#...#.##........##......#..
+##....#...#.......#..#........#
+....##........................#
+..................#..#.........
+..#....#........#..#.......#...
+#...#..#....#...##...........#.
+.........#..#..#.#.##..........
+....#.#..#.....#..#.#.#.#..#.##
+##................#.##.....#...
+.#.....###..#..#..#.....#....##
+...#...........#..........####.
+.#.....#....#......#.##..#.#...
+..#...##....#................#.
+........#.......#......#.#.....
+....#.#.#.#....#...#......#..#.
+...........#......#..#.........
+###...##......##.#..#....##....
+##....##.........#..#....###...
+#.#.....#....#......#...#..##..
+#....##.#..............#.##....
+.#........#.#.........#...#....
+......................#......#.
+........#..#..##.....#..#.#....
+..#...###.................#..#.
+...#...#............#..........
+.##.......#..#.........#....#..
+.#..............#....#....##...
+...............##..#.#.......##
+.#.....#....#...#..#.......#..#
+#..#.............#....#......#.
+.....#.#......#.........###..#.
+.#...#.#...............#....#..
+#......#.............#.........
+.#.##.#.####...#..#.##..#.....#
+.....#......#..#...#.......#...
+#........###...#.....#..#.....#
+....#.#.....#...#..........#...
+...#.#.......#.#......#..#.##..
+..#..........#.#..#.......#.#..
+#...#.#..............#...###.#.
+...#..#...#............###.....
+..#..#...#.#............#..#...
+.###.#.....................#..#
+....#....#..#.....##.##........
+#....#....#.#..#.........#.....
+.#.....##....#............##..#
+#....#.#...#...#..#.#......#...
+#.....##.....##.....##.#...##..
+...##...#..#..####.#........#..
+.........#...#......##..##..#..
+..#.....###.#..#..####.#.......
+.......#......#...#..##....#...
+.#.....#.#.#..#....#...#..##...
+..........#.#...#...#.#..#.....
+....#.....#........#.....##..#.
+..#.#.##.........#...##.....##.
+.........#.##....#............#
+............##.....#.......#.#.
+......#.....#...#..#..###......
+##.....#.......#...##.#....#...
+...........##......#..##...#.#.
+..#.#.#.#...#.......#....#...#.
+#.............#.....#.#...###..
+##....#.......#.....#..##.#....
+...#.......#....#.........##...
+......#.......#......##.##.....
+..#......#...#.#........#......
+....#.#....#.#.##......#.....#.
+#......#.........#..#....#.....
+........#..#....##.....#.......
+#......##....#.##....#......#..
+..#.......#............##.....#
+...........#...#...........#...
+#.......#...#....#....#...#.#.#
+..###..#........#........#.....
+..#..###...........#.#......#..
+.#...........#......#..........
+.#.......#.....#.......#.......
+..#......##.#............#....#
+#..........#.....#.#..#........
+.....#...##.##.......#......#..
+..........#.....#........#.#.#.
+....#......#.....#......#.#....
+.........#.#.#..#...##....#...#
+.........#.......#...##...#.#..
+.##........#...............#...
+.......#....#...........##.....
+.........###......#.........#.#
+......#.......#...#..........#.
+...#.#..........##......#...#..
+#.......#.#..........#.........
+................#..#......#..##
+.....#...#....#.#.....#........
+#.....#....#...........#....#..
+#....#.#..#...##....#...##.#...
+...#.....#......#.#....#..#..#.
+..#................#...#.#..##.
+..........#..............#..#.#
+.....##.....#..#.###...........
+....#.#......#.#...........#...
+.#....#.#.........##.#....#....
+.#.#........#........###....#..
+##.#................#...#..#...
+.......#......##..#.....#..#.#.
+...#............#......###...##
+#.#...........#.........#......
+.....#.#.#.................#...
+....#..............#...#.#.....
+...#.#.....##..#...............
+.#..##...#....##.....###..#....
+...............#...#...#.#.###.
+.###....#.....#...#.#......#...
+...#..#.....#.......#..##.#....
+...........#..#....##..#...#...
+...#...#..........#.......##.#.
+............#.#.......#........
+....#.........#.....#..........
+...#.###.##..#...##..####..#..#
+.#.#...#..#...................#
+.....#..#.....##..#............
+....#......#...##..#.##........
+...#...............#..#.....##.
+...#......#.........#.#..##....
+.#....#.##.......#......#......
+....#.......#....#..........#..
+#.#.#....###.#.#.............#.
+..##..###........#.#..#.#..#...
+......#.#............##.#...###
+.........#.#....#####.....##...
+............##......#.#..#.....
+...#.....#.....###....#........
+##..........####.##.#.#........
+....................##.....##.#
+#.#............#........#......
+....#...##.....#......#....#...
+...###.#..##..................#
+..###......#..............#.#.#
+.#...#...........#....#........
+....#............#..#..#.#.....
+...#.........#.#.........#.####
+..#...#...#...#...........#....
+...............#.#......##..#..
+#....#.#.......#.#..#......#..#
+........#.#....#..#...#..#...#.
+...#..#.......#...........#....
+...........#.......#...........
+.#......#................#.....
+....#.#.#...#......#..#...#....
+................#.#.#....#.....
+.........................##..#.
+.#...........#............##...
+#...............#.....##.#.#..#
+.........#.......###....#.....#
+....##...#...#.....#..#........
+........#.....#..#.#.#...#..#..
+......#.......#.#.........#.#..
+#......#............#...#....#.
+#..##...#..#................#..
+.##...#...#.....#.##.......#..#
+.......#.##........##..##......
+##.#..##...............#.....#.
+......#....#..##...#......###.#
+#........##..#....#.#......#...
+.#......##.#...#.#...#.........
+.#.#...#..#.............#......
+.##..........#..........#......
+.#.....#.....#..............#.#
+..#.........#..#.#.....#.#....#
+..#.##..............##...#..###
+....................#..........
+......###..#..#...........#....
+..#..........#.......#...#.....
+...#......#......#.............
+....##..............#.#.....#..
+........#.#......#..#........##
+.............#...#.#.........##
+...###...#..........##.......#.
+.#..........#...##..#.#.....#..
+##...#.........#...............
+......#....#....#.....#.....#..
+..........#....#...#...#..#...#
+...##....#.#.#..#...##.........
+#......#.#...##.###...#....#...
+##.......##.#......##..#...#...
+......#.............#.##.....##
+#.......###....####.#...##....#
+..#...#..#.......#..........#..
+#.....#..#..#..#.##...###...#..
+.....##.#..#..#..#.#....#...#..
+..#...#..................##....
+....#.#........##..............
+#...#.......##...#...#.#.......
+..#...#........##....#.#.......
+..........###...###...#......#.
+#.....#..###...##...##..#..#..#
+..#.....##.....#.......##..#.#.
+........#........#.........#...
+.................#....#.......#
+.......#...#.....#...#.#.......
+....##...............#...##...#
+.##...#................#...#...
+.............#.................
+.#..#....#....#.#....#.........
+.#.#..#..........#.......#.....
+.....##.....##...#..#..........
+#...#.#.........#......#..#....
+........#....#...#....#.#.##...
+....#..#........#...#...#......
+.#..#.....#.#...#.........#....
+.#..#..#...........#..#....#...
+....###.............#..#.......
+#......#..#..##..........#.#...
+#..#..#.##..#...#.#.#..........
+....###......#.##.....#....#...
+.##..#...#......##.#...........
+..#..#.......#.....#.##....#.#.
+.......#.#.#........#....##....
+..##...#....#...............###
+#..##..#...........#.#....##...
+...##..#.....................#.
+###......#....#....###..#...##.
+.........##............#..#...#
+..#..........#...#.#.#......#.#
+.......#.....##..##......#.##..
+#..........#.....##.#..........
+#.......#.#...#...#....#.......
+#...#.....##.......#.#..#.#.#..
+.........#.#.#..#..#...#.###...
+.................##...#....#...
+###.......#..........##...#....
+#.#..#.........#....##.#.......
+......#.#.....#........#.......
+.......#.#........#......#.#..#
+..............#..#...##....#..#
+#...........#...##.....#..#.#..
+..#....#..#.#.#...#..#....#.#..
+...##.#.....#..#...##..#.....#.
+..#.#................#........#
+......#...#.............#......
+.##............#....#...#..#...
+....#...#...........#.......#..
+.###..#.......#.............#.#
+.#.#....#.#...........#.#......
+...#.........#.........#..#....
+...#..........#.#.....#.#......
+.....#........#....##......#...
+..#.#.#......#..#.#......#....#
+.#.#..#................#.#.....
+.#.#.........##...#.......#.#.#
+#..#.....#...#..#...........#..
+..##......####......#..#....###
+#.....###....#.#........#..#..#
+..##.#...#.#..##..........#..#.
+#.........#.#.............#...#
+...#.#...#...#.#.#....##.......
+##.##...#.....#...#...........#
+....#........#.#.....#.........
+.................##..#..##...##
+.....##....#...#...#.....#..#..
+....#...#........#............#
+..#...........##....#...#...##.
+.....#......#.........#..##.#..
diff --git a/3/part1.c b/3/part1.c
new file mode 100644
index 0000000..19f3bf3
--- /dev/null
+++ b/3/part1.c
@@ -0,0 +1,35 @@
+#include <stdbool.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#define INC_RIGHT 3
+
+int count_trees(const char * filename)
+{
+ FILE * file = fopen(filename, "r");
+
+ // Include space for newline and string terminator
+ char buffer[64] = { 0 };
+ // Start is always safe
+ fgets(buffer, 64, file);
+ // strlen includes the newline
+ int width = strchr(buffer, '\n') - buffer;
+
+ int pos = INC_RIGHT;
+ int hit = 0;
+ while (fgets(buffer, 64, file)) {
+ if (buffer[pos] == '#') {
+ hit++;
+ }
+
+ pos = (pos + INC_RIGHT) % width;
+ }
+
+ return hit;
+}
+
+int main()
+{
+ printf("%i", count_trees("input"));
+}
diff --git a/3/part2.c b/3/part2.c
new file mode 100644
index 0000000..d7c4ce9
--- /dev/null
+++ b/3/part2.c
@@ -0,0 +1,39 @@
+#include <stdbool.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+int count_trees(int inc_right, int inc_down, const char * filename)
+{
+ FILE * file = fopen(filename, "r");
+
+ // Include space for newline and string terminator
+ char buffer[64] = { 0 };
+ // Start is always safe
+ fgets(buffer, 64, file);
+ // strlen includes the newline
+ int width = strchr(buffer, '\n') - buffer;
+
+ int pos = inc_right;
+ int hit = 0;
+ for (int i = 1; fgets(buffer, 64, file); i++) {
+ if (inc_down != 1 && i % inc_down != 0)
+ {
+ continue;
+ }
+
+ if (buffer[pos] == '#') {
+ hit++;
+ }
+
+ pos = (pos + inc_right) % width;
+ }
+
+ return hit;
+}
+
+int main()
+{
+ long mul = (long)count_trees(1, 1, "input") * count_trees(3, 1, "input") * count_trees(5, 1, "input") * count_trees(7, 1, "input") * count_trees(1, 2, "input");
+ printf("%li\n", mul);
+}