summary refs log tree commit diff homepage
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--2022/day15.awk26
1 files changed, 26 insertions, 0 deletions
diff --git a/2022/day15.awk b/2022/day15.awk
new file mode 100644
index 0000000..0840487
--- /dev/null
+++ b/2022/day15.awk
@@ -0,0 +1,26 @@
+BEGIN {
+	FS = "[ =,:]+";
+	y = 2000000;
+}
+function abs(x) {
+	return (x < 0 ? -x : x);
+}
+function dist(x1, y1, x2, y2) {
+	return abs(x1 - x2) + abs(y1 - y2);
+}
+{
+	if ($14 == y) B[$12] = 1;
+	r = dist($4, $6, $12, $14);
+	if (abs(y - $6) <= r) {
+		n = r - abs(y - $6);
+		for (x = $4-n; x <= $4+n; ++x) {
+			Y[x] = 1;
+		}
+	}
+}
+END {
+	for (x in B) {
+		delete Y[x];
+	}
+	print length(Y);
+}
tJune McEnroe lex is a waste of time. 2019-05-29Add xx -p optionJune McEnroe 2019-05-27Add FrontierJune McEnroe 2019-05-27Break nicks with ZWNJJune McEnroe This should prevent bad wrapping. 2019-05-26Add DawnJune McEnroe 2019-05-20Declare vasprintf(3) for GNUJune McEnroe who the fuck is scraeming "#define _GNU_SOURCE" at my house. show yourself, coward. i will never #define _GNU_SOURCE 2019-05-20Fix comparison warning in ttpreJune McEnroe 2019-05-20Add AuthorityJune McEnroe 2019-05-19Specify precedence of unary versions of operatorsJune McEnroe 2019-05-18Add compound assignment operators to orderJune McEnroe 2019-05-15Support simple assignment in orderJune McEnroe 2019-05-15Implement sizeof in orderJune McEnroe 2019-05-15Add orderJune McEnroe 2019-05-12Add T suffix in bitJune McEnroe 2019-05-10Highlight yacc and lex files as CJune McEnroe Their %-prefixed directives should probably be highlighted Macro. 2019-05-10Use val instead of suboptargJune McEnroe suboptarg doesn't exist in GNU. Hopefully BSD getsubopt also sets val on failure? 2019-05-09Add Parable of the SowerJune McEnroe 2019-05-07Add bit without buildJune McEnroe Need to do some stuff in the Makefile for lex and yacc and generating HTML pages for it. 2019-05-04Fix MANDIR typoJune McEnroe 2019-05-04Move relay to binJune McEnroe