From e0c2037ee5cede636e907e8af462371ee0e775db Mon Sep 17 00:00:00 2001 From: Adam Spragg Date: Sun, 4 Dec 2022 16:47:21 +0000 Subject: Advent of code 2022 problems 1-4 --- 3a.c | 65 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 3a.c (limited to '3a.c') diff --git a/3a.c b/3a.c new file mode 100644 index 0000000..676db86 --- /dev/null +++ b/3a.c @@ -0,0 +1,65 @@ + +#include +#include +#include + + +int +chrcmp(void const * a, void const * b) +{ + return (*(char const *) a) - *((char const *) b); +} + + +int +priority(int c) +{ + if (c >= 'A' && c <= 'Z') + return 27 + c - 'A'; + if (c >= 'a' && c <= 'z') + return 1 + c - 'a'; + fprintf(stderr, "Unexpected priority request: %c\n", c); + return -1; +} + + +int +main() +{ + char buf[BUFSIZ]; + int score = 0; + + while (fgets(buf, sizeof(buf), stdin)) { + int len, i, j; + + len = strlen(buf); + if (len && buf[len - 1] == '\n') + --len; + if (len % 2 == 1) + fprintf(stderr, "Unexpected length: %d\n", len); + + qsort(buf, len / 2, 1, chrcmp); + qsort(buf + len / 2, len / 2, 1, chrcmp); + + i = 0; + j = len / 2; + while (i < len / 2 && j < len) { + if (buf[i] < buf[j]) + ++i; + else if (buf[j] < buf[i]) + ++j; + else + break; + } + if (i >= len / 2 || j >= len) { + fprintf(stderr, "No match found in %s\n", buf); + return -1; + } + score += priority(buf[i]); + } + + printf("Score: %d\n", score); + + return 0; +} + -- cgit v1.2.1