AOC2023: implement day1
This commit is contained in:
parent
3aaa755c51
commit
6a7335e5c9
|
@ -1,6 +1,129 @@
|
||||||
|
#include <ctype.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
int main()
|
int puzzle1(FILE* fp)
|
||||||
{
|
{
|
||||||
printf("hello world\n");
|
int sum = 0;
|
||||||
|
|
||||||
|
char buffer[128];
|
||||||
|
while (fgets(buffer, sizeof(buffer), fp))
|
||||||
|
{
|
||||||
|
int line_len = strlen(buffer);
|
||||||
|
|
||||||
|
for (int i = 0; i < line_len; i++)
|
||||||
|
{
|
||||||
|
if (!isdigit(buffer[i]))
|
||||||
|
continue;
|
||||||
|
sum += 10 * (buffer[i] - '0');
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = line_len - 1; i >= 0; i--)
|
||||||
|
{
|
||||||
|
if (!isdigit(buffer[i]))
|
||||||
|
continue;
|
||||||
|
sum += buffer[i] - '0';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return sum;
|
||||||
|
}
|
||||||
|
|
||||||
|
int puzzle2(FILE* fp)
|
||||||
|
{
|
||||||
|
const char* str_digits[] = {
|
||||||
|
"zero",
|
||||||
|
"one",
|
||||||
|
"two",
|
||||||
|
"three",
|
||||||
|
"four",
|
||||||
|
"five",
|
||||||
|
"six",
|
||||||
|
"seven",
|
||||||
|
"eight",
|
||||||
|
"nine"
|
||||||
|
};
|
||||||
|
|
||||||
|
int sum = 0;
|
||||||
|
|
||||||
|
char buffer[128];
|
||||||
|
while (fgets(buffer, sizeof(buffer), fp))
|
||||||
|
{
|
||||||
|
int line_len = strlen(buffer);
|
||||||
|
|
||||||
|
int digit = -1;
|
||||||
|
|
||||||
|
for (int i = 0; i < line_len; i++)
|
||||||
|
{
|
||||||
|
if (isdigit(buffer[i]))
|
||||||
|
{
|
||||||
|
digit = buffer[i] - '0';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
for (int j = 0; j < 10; j++)
|
||||||
|
{
|
||||||
|
if (line_len - i < strlen(str_digits[j]))
|
||||||
|
continue;
|
||||||
|
if (strncmp(buffer + i, str_digits[j], strlen(str_digits[j])) == 0)
|
||||||
|
{
|
||||||
|
digit = j;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (digit != -1)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
sum += 10 * digit;
|
||||||
|
|
||||||
|
digit = -1;
|
||||||
|
|
||||||
|
for (int i = line_len - 1; i >= 0; i--)
|
||||||
|
{
|
||||||
|
if (isdigit(buffer[i]))
|
||||||
|
{
|
||||||
|
digit = buffer[i] - '0';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
for (int j = 0; j < 10; j++)
|
||||||
|
{
|
||||||
|
if (i < strlen(str_digits[j]))
|
||||||
|
continue;
|
||||||
|
if (strncmp(buffer + i - strlen(str_digits[j]), str_digits[j], strlen(str_digits[j])) == 0)
|
||||||
|
{
|
||||||
|
digit = j;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (digit != -1)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
sum += digit;
|
||||||
|
}
|
||||||
|
|
||||||
|
return sum;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char** argv)
|
||||||
|
{
|
||||||
|
const char* file_path = "/usr/share/aoc2023/day1_input.txt";
|
||||||
|
if (argc >= 2)
|
||||||
|
file_path = argv[1];
|
||||||
|
|
||||||
|
FILE* fp = fopen(file_path, "r");
|
||||||
|
if (fp == nullptr)
|
||||||
|
{
|
||||||
|
perror("fopen");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("puzzle1: %d\n", puzzle1(fp));
|
||||||
|
|
||||||
|
fseek(fp, 0, SEEK_SET);
|
||||||
|
|
||||||
|
printf("puzzle2: %d\n", puzzle2(fp));
|
||||||
|
|
||||||
|
fclose(fp);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue