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
|
#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;
}
fclose(file);
return hit;
}
int main(int argc, char *argv[])
{
long mul = (long)count_trees(1, 1, argv[1]) * count_trees(3, 1, argv[1]) * count_trees(5, 1, argv[1]) * count_trees(7, 1, argv[1]) * count_trees(1, 2, argv[1]);
printf("%li\n", mul);
}
|