summaryrefslogtreecommitdiff
path: root/3/part2.c
diff options
context:
space:
mode:
authorBond_009 <bond.009@outlook.com>2020-12-03 14:42:50 +0100
committerBond_009 <bond.009@outlook.com>2020-12-03 14:42:50 +0100
commit1b5677661fd8bd513d6f81ba6e19e1a23498d3cf (patch)
tree275323daffb56a923cbcc9026c5726a85d3b1e85 /3/part2.c
parentd4019c536df8c2abc411825b4501c7a80a83fe0c (diff)
Add day 3
Diffstat (limited to '3/part2.c')
-rw-r--r--3/part2.c39
1 files changed, 39 insertions, 0 deletions
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);
+}