]> www.fi.muni.cz Git - aoc.git/blob - 2016/26.pl
The rest of Year 2016
[aoc.git] / 2016 / 26.pl
1 #!/usr/bin/perl -w
2
3 use strict;
4 use v5.30;
5
6 my $in = 1362;
7 # my $in = 10;
8
9 my %maze;
10 $; = ',';
11 sub is_wall {
12         my ($x, $y) = @_;
13         return $maze{$x,$y} if exists $maze{$x,$y};
14
15         my $sum = $in + $x*$x + 3*$x + 2*$x*$y + $y + $y*$y;
16         my $bin = sprintf("%b", $sum);
17         say "$x $y => $sum => $bin";
18         my $count = () = $bin =~ /1/g;
19         return $maze{$x,$y} = $count & 1;
20 }
21
22 say is_wall(0, 0);
23 say is_wall(3, 5);
24 say is_wall(9, 2);
25
26 my %seen = ( "1,1" => 1 );
27 my @paths = ( [ 1, 1, 0 ] );
28 while (@paths) {
29         my $p = shift @paths;
30         my ($x, $y, $steps) = @$p;
31         for my $d ([0, 1], [0, -1], [1, 0], [-1, 0]) {
32                 my $x1 = $x + $d->[0];
33                 my $y1 = $y + $d->[1];
34                 next if $x1 < 0 || $y1 < 0;
35                 next if $seen{$x1,$y1};
36                 next if is_wall($x1, $y1);
37                 next if $steps >= 50;
38                 $seen{$x1,$y1}++;
39                 push @paths, [$x1, $y1, $steps+1];
40         }
41 }
42 say scalar keys %seen;