From 2ae8fa06680c32563e07a1efb57bc7b2e81e49de Mon Sep 17 00:00:00 2001 From: kartofen Date: Tue, 6 Dec 2022 23:18:32 +0200 Subject: day 6 --- Advent-of-Code-2022/aoc-6/main.c | 56 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 Advent-of-Code-2022/aoc-6/main.c (limited to 'Advent-of-Code-2022/aoc-6/main.c') diff --git a/Advent-of-Code-2022/aoc-6/main.c b/Advent-of-Code-2022/aoc-6/main.c new file mode 100644 index 0000000..d9cf652 --- /dev/null +++ b/Advent-of-Code-2022/aoc-6/main.c @@ -0,0 +1,56 @@ +#include +#include +#include + +#if 0 + #define PART(line) part(line, 4) +#else + #define PART(line) part(line, 14) +#endif + +#if 0 + #define FILENAME "sample.txt" +#else + #define FILENAME "input.txt" +#endif + +void part(char *line, int n) +{ + n--; + int times_seen['z'-'a'+1] = {0}; + + for(ulong i = n; i < strlen(line) - 1; i++) + { + int stop = 0; + for(ulong j = i-n; j <= i && !stop; j++) + if(++(times_seen[line[j]-'a']) > 1) + stop = 1; + + memset(times_seen, 0, sizeof(times_seen)); + if(stop) continue; + + printf("%ld\n", i + 1); + return; + } +} + +void parse() +{ + FILE *fp = fopen(FILENAME, "r"); + if(!fp) { + fprintf(stderr, "ERROR: Could not open file: %s\n", FILENAME); + exit(1); + } + + char line[4096]; + while(fgets(line, sizeof(line), fp)) + PART(line); + + fclose(fp); +} + +int main(void) +{ + parse(); + return 0; +} -- cgit v1.2.3