pretty blinkenlights
This commit is contained in:
29
day4.c
29
day4.c
@@ -12,7 +12,7 @@ unsigned char test[] = {
|
|||||||
#embed "day4_test.txt"
|
#embed "day4_test.txt"
|
||||||
};
|
};
|
||||||
|
|
||||||
static
|
alignas (0x40) static
|
||||||
unsigned char buf[UINT16_MAX];
|
unsigned char buf[UINT16_MAX];
|
||||||
|
|
||||||
static
|
static
|
||||||
@@ -31,9 +31,9 @@ unsigned long do_part1(size_t file_len, unsigned char file[file_len]) {
|
|||||||
|
|
||||||
unsigned line_count = file_len / file_stride;
|
unsigned line_count = file_len / file_stride;
|
||||||
|
|
||||||
unsigned line_stride = file_stride + 1;
|
unsigned line_stride = MAX(file_stride + 1, 0x40);
|
||||||
|
|
||||||
memset(d, '0', sizeof(buf));
|
memset(d, 0, sizeof(buf));
|
||||||
|
|
||||||
#if DBG
|
#if DBG
|
||||||
printh(file_stride); print("\n");
|
printh(file_stride); print("\n");
|
||||||
@@ -59,7 +59,7 @@ unsigned long do_part1(size_t file_len, unsigned char file[file_len]) {
|
|||||||
unsigned char *l = buf + line_stride + 1;
|
unsigned char *l = buf + line_stride + 1;
|
||||||
for (unsigned i = line_count; i; i--) {
|
for (unsigned i = line_count; i; i--) {
|
||||||
d = l;
|
d = l;
|
||||||
for (unsigned j = line_stride - 2; j; j--) {
|
for (unsigned j = file_stride - 1; j; j--) {
|
||||||
if (*d == '@') {
|
if (*d == '@') {
|
||||||
unsigned neighbors = 0
|
unsigned neighbors = 0
|
||||||
+ (*(d - 1 - line_stride) == '@')
|
+ (*(d - 1 - line_stride) == '@')
|
||||||
@@ -69,9 +69,18 @@ unsigned long do_part1(size_t file_len, unsigned char file[file_len]) {
|
|||||||
+ (*(d + 1 - 0) == '@')
|
+ (*(d + 1 - 0) == '@')
|
||||||
+ (*(d - 1 + line_stride) == '@')
|
+ (*(d - 1 + line_stride) == '@')
|
||||||
+ (*(d - 0 + line_stride) == '@')
|
+ (*(d - 0 + line_stride) == '@')
|
||||||
+ (*(d + 1 + line_stride) == '@');
|
+ (*(d + 1 + line_stride) == '@')
|
||||||
|
+ (*(d - 1 - line_stride) == 'X')
|
||||||
|
+ (*(d - 0 - line_stride) == 'X')
|
||||||
|
+ (*(d + 1 - line_stride) == 'X')
|
||||||
|
+ (*(d - 1 - 0) == 'X')
|
||||||
|
+ (*(d + 1 - 0) == 'X')
|
||||||
|
+ (*(d - 1 + line_stride) == 'X')
|
||||||
|
+ (*(d - 0 + line_stride) == 'X')
|
||||||
|
+ (*(d + 1 + line_stride) == 'X');
|
||||||
if (neighbors < 4) {
|
if (neighbors < 4) {
|
||||||
result++;
|
result++;
|
||||||
|
*d = 'X';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
d++;
|
d++;
|
||||||
@@ -98,9 +107,9 @@ unsigned long do_part2(size_t file_len, unsigned char file[file_len]) {
|
|||||||
|
|
||||||
unsigned line_count = file_len / file_stride;
|
unsigned line_count = file_len / file_stride;
|
||||||
|
|
||||||
unsigned line_stride = file_stride + 1;
|
unsigned line_stride = MAX(file_stride + 1, 0x40);
|
||||||
|
|
||||||
memset(d, '0', sizeof(buf));
|
memset(d, 0, sizeof(buf));
|
||||||
|
|
||||||
#if DBG
|
#if DBG
|
||||||
printh(file_stride); print("\n");
|
printh(file_stride); print("\n");
|
||||||
@@ -127,7 +136,7 @@ unsigned long do_part2(size_t file_len, unsigned char file[file_len]) {
|
|||||||
for (unsigned i = line_count; i; i--) {
|
for (unsigned i = line_count; i; i--) {
|
||||||
line_start:
|
line_start:
|
||||||
d = l;
|
d = l;
|
||||||
for (unsigned j = line_stride - 2; j; j--) {
|
for (unsigned j = file_stride - 1; j; j--) {
|
||||||
if (*d == '@') {
|
if (*d == '@') {
|
||||||
unsigned neighbors = 0
|
unsigned neighbors = 0
|
||||||
+ (*(d - 1 - line_stride) == '@')
|
+ (*(d - 1 - line_stride) == '@')
|
||||||
@@ -161,9 +170,9 @@ line_start:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define RUN_TEST1 1
|
#define RUN_TEST1 1
|
||||||
#define RUN_PART1 1
|
#define RUN_PART1 0
|
||||||
#define RUN_TEST2 1
|
#define RUN_TEST2 1
|
||||||
#define RUN_PART2 1
|
#define RUN_PART2 0
|
||||||
|
|
||||||
#define TEST1_EXPECT 13
|
#define TEST1_EXPECT 13
|
||||||
#define TEST2_EXPECT 43
|
#define TEST2_EXPECT 43
|
||||||
|
|||||||
Reference in New Issue
Block a user