summary refs log tree commit diff homepage
path: root/2018
diff options
context:
space:
mode:
Diffstat (limited to '')
-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);
 }
colspan='3' class='logmsg'> 2021-01-12Move hilex out of hilex directoryJune McEnroe 2021-01-12Consolidate hilex formatters into hilex.cJune McEnroe 2021-01-12Remove hacky tagging from hilexJune McEnroe God that makes the lexers so much simpler. 2021-01-12Add htagml -iJune McEnroe 2021-01-12Render tag index in HTMLJune McEnroe 2021-01-12Add htagml -xJune McEnroe 2021-01-12Prevent matching the same tag twiceJune McEnroe 2021-01-12Process htagml file line by lineJune McEnroe This simplifies some things, adds support for line number tag definitions, and should enable combining htagml with other preprocessors in the future. 2021-01-12Split fields by tab onlyJune McEnroe Also don't fail hard on non-forward-search definitions. 2021-01-12List both Makefile and html.sh under README.7June McEnroe 2021-01-12Add htagml exampleJune McEnroe 2021-01-12Use mandoc and htagml for bin htmlJune McEnroe 2021-01-12Add htagmlJune McEnroe 2021-01-12Replace causal.agency with a simple mdoc pageJune McEnroe 2021-01-11Publish "Using vi"June McEnroe 2021-01-11Enable diff.colorMovedJune McEnroe 2021-01-10Set less search case-insensitiveJune McEnroe 2021-01-10Set EXINITJune McEnroe neovim is laggy as hell in my OpenBSD VM, so I switched to vi so I could type without getting frustrated. 2021-01-09Add c -t flag to print expression typeJune McEnroe Also add missing float case. 2021-01-05Update taglineJune McEnroe