day 1 finished
parent
76c8632ae6
commit
5a9edbcad0
@ -0,0 +1,9 @@
|
|||||||
|
CC=gcc
|
||||||
|
CFLAGS=-std=gnu99 -O2 -g
|
||||||
|
PROJECT=aoc_day1
|
||||||
|
|
||||||
|
%.o: %.c
|
||||||
|
$(CC) -c -o $@ $< $(CFLAGS)
|
||||||
|
|
||||||
|
$(PROJECT): aoc_day1.o
|
||||||
|
$(CC) -o aoc_day1 aoc_day1.o
|
Binary file not shown.
@ -0,0 +1,64 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#define INPUT_FILE ("input.txt")
|
||||||
|
#define ARR_LEN (2000)
|
||||||
|
|
||||||
|
int main(int argc, char** argv)
|
||||||
|
{
|
||||||
|
int measurements[ARR_LEN];
|
||||||
|
memset(measurements, 0, ARR_LEN * sizeof(int));
|
||||||
|
FILE* fp = fopen(INPUT_FILE, "r");
|
||||||
|
if(fp == NULL)
|
||||||
|
{
|
||||||
|
printf("File failed to open for reading...");
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
char* line = NULL;
|
||||||
|
size_t len = 0;
|
||||||
|
ssize_t rc = 0;
|
||||||
|
uint16_t ct = 0;
|
||||||
|
|
||||||
|
// counter that keeps track of how many times a depth measurement has increased
|
||||||
|
int increase_count = 0;
|
||||||
|
|
||||||
|
if((rc = getline(&line, &len, fp)) < 0)
|
||||||
|
{
|
||||||
|
printf("Bad read...\n");
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
measurements[ct++] = strtol(line, NULL, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
while((rc = getline(&line, &len, fp)) >= 0)
|
||||||
|
{
|
||||||
|
measurements[ct] = strtol(line, NULL, 10);
|
||||||
|
if(measurements[ct] - measurements[ct - 1] > 0)
|
||||||
|
{
|
||||||
|
increase_count++;
|
||||||
|
}
|
||||||
|
ct++;
|
||||||
|
}
|
||||||
|
printf("Increase count: %d\n", increase_count);
|
||||||
|
|
||||||
|
// part 2
|
||||||
|
int sum_increase_count = 0;
|
||||||
|
for(int ind = 2; ind < ARR_LEN - 1; ind++)
|
||||||
|
{
|
||||||
|
int sum_one = measurements[ind - 2] +
|
||||||
|
measurements[ind - 1] +
|
||||||
|
measurements[ind];
|
||||||
|
int sum_two = measurements[ind - 1] +
|
||||||
|
measurements[ind] +
|
||||||
|
measurements[ind + 1];
|
||||||
|
sum_increase_count += (sum_two > sum_one);
|
||||||
|
}
|
||||||
|
printf("Sum increase count: %d\n", sum_increase_count);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Binary file not shown.
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue