diff options
author | Thomas Voss <mail@thomasvoss.com> | 2022-12-02 16:54:18 +0100 |
---|---|---|
committer | Thomas Voss <mail@thomasvoss.com> | 2022-12-02 16:54:18 +0100 |
commit | 093de3f52b0b7dfb7cc42e05c9c4267c7011c001 (patch) | |
tree | 70e1f1764061fdcb96c0f95ad47d4994ca1c26e4 /2016/01/puzzles.awk | |
parent | 231b40909b5a3c2e202bcb48ab40e42a4213bdff (diff) |
Add 2016 day 1 solutions
Diffstat (limited to '2016/01/puzzles.awk')
-rw-r--r-- | 2016/01/puzzles.awk | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/2016/01/puzzles.awk b/2016/01/puzzles.awk new file mode 100644 index 0000000..c20a12a --- /dev/null +++ b/2016/01/puzzles.awk @@ -0,0 +1,27 @@ +#!/usr/bin/gawk -f + +function abs(n) { return n < 0 ? -n : n } + +function move(n) { + # START PART 1 + d == 0 ? y += n : \ + d == 1 ? x += n : \ + d == 2 ? y -= n : \ + x -= n + # END PART 1 START PART 2 + for (i = 1; i <= n; i++) { + d == 0 ? y++ : \ + d == 1 ? x++ : \ + d == 2 ? y-- : \ + x-- + if (map[x, y]++) + exit + } + # END PART 2 +} + +BEGIN { RS = ", "; FPAT = "[LR]|[0-9]+" } +/L/ { if (--d == -1) d = 3 } +/R/ { if (++d == +4) d = 0 } + { move($2) } +END { print abs(x) + abs(y) } |