diff options
author | kartofen <mladenovnasko0@gmail.com> | 2022-07-31 11:46:17 +0300 |
---|---|---|
committer | kartofen <mladenovnasko0@gmail.com> | 2022-07-31 11:46:17 +0300 |
commit | aec1c07260257ba7c28eff53f422ddb7daaf316a (patch) | |
tree | 88b279cb646bad60c3d55bdd01bb323065fca519 /Advent-of-Code-2021/AOC-15/aoc-15.c |
Big Bang
Diffstat (limited to 'Advent-of-Code-2021/AOC-15/aoc-15.c')
-rw-r--r-- | Advent-of-Code-2021/AOC-15/aoc-15.c | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/Advent-of-Code-2021/AOC-15/aoc-15.c b/Advent-of-Code-2021/AOC-15/aoc-15.c new file mode 100644 index 0000000..c7e1157 --- /dev/null +++ b/Advent-of-Code-2021/AOC-15/aoc-15.c @@ -0,0 +1,128 @@ +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#define min(a, b) (((a) < (b)) ? (a) : (b)) + +#if 0 + #define N 1 +#else + #define N 5 +#endif + + +// part 2 doesnt work with input for some reason bruh +#if 1 + #define FILE_P "sample.txt" + #define T_CAP 10 * N + #define T_CAP_S 10 +#else + #define FILE_P "input.txt" + #define T_CAP 100 * N + #define T_CAP_S 100 +#endif + +int table[T_CAP][T_CAP]; + +void ParseInput(char *filepath) +{ + char ch; + FILE *fp; + fp = fopen(filepath, "r"); + + if(fp == NULL) + { + fprintf(stderr, "ERROR: something with file idk fuck you"); + exit(EXIT_FAILURE); + } + + int i = 0; + int j = 0; + while((ch = fgetc(fp)) != EOF) + { + if(ch == '\n') { i += 1; j = 0; continue; } + + table[i][j] = (ch - '0'); + j += 1; + } + + fclose(fp); +} + +void FindRisk() +{ + // dont add to total risk + table[0][0] = 0; + + for(int i=1; i<T_CAP; i++) table[i][0] += table[i-1][0]; + for(int j=1; j<T_CAP; j++) table[0][j] += table[0][j-1]; + + for(int i=1; i<T_CAP; i++) + { + for(int j=1; j<T_CAP; j++) + { + table[i][j] += min(table[i][j-1], table[i-1][j]); + } + } + +} + +void Part1() +{ + ParseInput(FILE_P); + FindRisk(); + printf("PART1: %d\n", table[T_CAP-1][T_CAP-1]); +} + +void ReconstructMap() +{ + for(int j=0; j<T_CAP_S; j++) + for(int n=T_CAP_S; n<T_CAP; n+=T_CAP_S) + for(int i=0; i<T_CAP_S; i++) + { + if(table[i+n-T_CAP_S][j] != 9) + table[i+n][j] = table[i+n-T_CAP_S][j] + 1; + else + table[i+n][j] = 1; + } + + for(int i=0; i<T_CAP; i++) + for(int n=T_CAP_S; n<T_CAP; n+=T_CAP_S) + for(int j=0; j<T_CAP_S; j++) + { + if(table[i][j+n-T_CAP_S] != 9) + table[i][j+n] = table[i][j+n-T_CAP_S] + 1; + else + table[i][j+n] = 1; + } +} + +void Part2() +{ + ParseInput(FILE_P); + ReconstructMap(); + FindRisk(); + printf("PART2: %d\n", table[T_CAP-1][T_CAP-1]); +} + +void PrintTable() +{ + for(int i=0; i<T_CAP; i++) + { + for(int j=0; j<T_CAP; j++) + { + printf("%d", table[i][j]); + } + printf("\n"); + } +} + +int main(void) +{ + memset(table, 0, sizeof(table)); + // Part1(); + Part2(); + + return 0; +} + |