summary refs log tree commit diff homepage
path: root/2018
diff options
context:
space:
mode:
Diffstat (limited to '2018')
-rw-r--r--2018/day12.c25
1 files changed, 19 insertions, 6 deletions
diff --git a/2018/day12.c b/2018/day12.c
index 5f2f04e..d71e592 100644
--- a/2018/day12.c
+++ b/2018/day12.c
@@ -3,8 +3,9 @@
 #include <string.h>
 
 typedef unsigned uint;
+typedef unsigned long ulong;
 
-enum { Zero = 128, Len = Zero * 2 };
+enum { Zero = 256, Len = Zero * 2 };
 struct State {
 	char pots[Len];
 };
@@ -29,7 +30,16 @@ int main() {
 		rulen++;
 	}
 
-	for (uint g = 0; g < 20; ++g) {
+	ulong g;
+	for (g = 0; g < 50000000000L; ++g) {
+		if (g == 20) {
+			int sum = 0;
+			for (int i = 0; i < Len; ++i) {
+				if (state.pots[i] == '#') sum += i - Zero;
+			}
+			printf("%d\n", sum);
+		}
+
 		struct State next;
 		memset(next.pots, '.', Len);
 		for (uint i = 2; i < Len - 2; ++i) {
@@ -39,12 +49,15 @@ int main() {
 				break;
 			}
 		}
+		if (next.pots[2] == '#' || next.pots[Len - 3] == '#') abort();
+
+		if (!memcmp(&next.pots[1], state.pots, Len - 1)) break;
 		state = next;
 	}
 
-	int sum = 0;
-	for (int i = 0; i < Len; ++i) {
-		if (state.pots[i] == '#') sum += i - Zero;
+	long sum = 0;
+	for (long i = 0; i < Len; ++i) {
+		if (state.pots[i] == '#') sum += (50000000000L - g) + i - Zero;
 	}
-	printf("%d\n", sum);
+	printf("%ld\n", sum);
 }
title='2019-08-13 13:02:25 -0400'>2019-08-13Add The Calculating StarsJune McEnroe 2019-08-12Make dtch one command, add sinkingJune McEnroe 2019-08-03Add ImagoJune McEnroe 2019-07-29Add KindredJune McEnroe 2019-07-27Clean up home filesJune McEnroe 2019-07-27Fix shell script style in ~/.local/binJune McEnroe 2019-07-27Shell script style passJune McEnroe 2019-07-27Add c11.pdfJune McEnroe 2019-07-27Move pdf script to MakefileJune McEnroe 2019-07-27Update macOS neovim to 0.3.8June McEnroe Which somehow still doesn't include my man fix. 2019-07-27Rewrite port makefiles consistentlyJune McEnroe 2019-07-27Rewrite Makefile once more with more organizationJune McEnroe 2019-07-27Reference png.h in bin.7June McEnroe 2019-07-27Revert "Use scheme to style HTMLs"June McEnroe This reverts commit 46237a457ff3c9a813a56f2a442c115bf8610cbc. I don't know why but I don't like it. 2019-07-27Remove scheme text linkJune McEnroe No standard base64 encoder so no way to maintain it. 2019-07-26Update Dark.terminalJune McEnroe Why are the blobs so much bigger now? 2019-07-26Lighten dark whiteJune McEnroe 2019-07-25Add png.3 man pageJune McEnroe 2019-07-25Use scheme to style HTMLsJune McEnroe 2019-07-25Don't match comments in strings in makeJune McEnroe 2019-07-25Generate index.html with links from bin.7June McEnroe 2019-07-24Warn when date has changedJune McEnroe 2019-07-24Add whenJune McEnroe When? Now. 2019-07-24Remove histedit from bitJune McEnroe