aboutsummaryrefslogtreecommitdiff
path: root/advent-of-code/2022/10/2.c
blob: 1abcb7e83f873ebc471c58a4669ae3c9f35d85e7 (plain)
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
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <stdbool.h>

#include <str.h>

char screen[6][40];

int regx = 0;
int time = 0;

void process() {
    if (time >= 240) return;
    int delta = time % 40 - regx;
    if (delta <= 2 && delta >= 0) {
        screen[time / 40][time % 40] = '#';
    }
}

void tick(int value) {
    process();
    time++;
    regx += value;
}

int main() {
    memset(screen, '.', 240);
    FILE *fp = fopen("input", "r");
    while (true) {
        char *rawline = fgetline(fp);
        if (rawline == NULL) break;
        char *line = str_strip(rawline);
        free(rawline);
        char** words = str_split(line, ' ');
        if (words == NULL) {
            free(line);
            continue;
        }
        if (words[0] == NULL) {
            free(line); free(words);
            continue;
        }
        if (strcmp(words[0], "noop") == 0) {
            tick(0);
        } else if (strcmp(words[0], "addx") == 0) {
            tick(0);
            char *ptr;
            int value = strtol(words[1], &ptr, 10);
            tick(value);
        }
        str_list_free(words);
        free(line);
    }
    for (int i = 0; i < 6; i++) {
        for (int j = 0; j < 40; j++) {
            printf("%c", screen[i][j]);
        }
        printf("\n");
    }
    return 0;
}