]> www.fi.muni.cz Git - aoc.git/blob - 2018/19.pl
Day 25: examining the input
[aoc.git] / 2018 / 19.pl
1 #!/usr/bin/perl -w
2
3 use v5.30;
4 use strict;
5
6 my @pts;
7 my @vel;
8 while (<>) {
9         my ($x, $y, $dx, $dy) = /(-?\d+)/g;
10         push @pts, [ $x, $y ];
11         push @vel, [ $dx, $dy ];
12 }
13
14 $; = ',';
15 my $printed;
16
17 while (1) {
18         my %map;
19         my ($minx, $miny, $maxx, $maxy);
20         for my $i (0 .. $#pts) {
21                 my $pt = $pts[$i];
22                 my $ve = $vel[$i];
23                 $pt->[$_] += $ve->[$_] for 0 .. 1;
24                 $maxx = $pt->[0] if !defined $maxx || $maxx < $pt->[0];
25                 $maxy = $pt->[1] if !defined $maxy || $maxy < $pt->[1];
26                 $minx = $pt->[0] if !defined $minx || $minx > $pt->[0];
27                 $miny = $pt->[1] if !defined $miny || $miny > $pt->[1];
28                 $map{$pt->[0],$pt->[1]}++;
29         }
30         my $dim = $maxx-$minx + $maxy-$miny;
31         if ($dim < 200) {
32                 for my $y ($miny .. $maxy) {
33                         for my $x ($minx .. $maxx) {
34                                 print $map{$x,$y} ? '#' : '.';
35                         }
36                         print "\n";
37                 }
38                 $printed = 1;
39         } elsif ($printed) {
40                 last;
41         }
42         say "dim=$dim\n";
43 }
44
45
46         
47
48