aboutsummaryrefslogtreecommitdiff
path: root/2016/01/puzzles.awk
blob: c20a12a2af9630f459aa9b46240110bb469629d5 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
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) }