35 lines
701 B
Perl
35 lines
701 B
Perl
use 5.20.0;
|
|
|
|
use experimental qw/ postderef /;
|
|
|
|
my @levels = (
|
|
map { chomp; [
|
|
map { $_ eq '^' } split '' ] } <>
|
|
);
|
|
|
|
use DDP;
|
|
|
|
p @levels;
|
|
my $sum = 0;
|
|
use List::AllUtils qw/ sum /;
|
|
|
|
for ( 1..400000-1 ) {
|
|
my @previous = ( 0, $levels[-1]->@* );
|
|
my @new;
|
|
while( @previous >= 2 ) {
|
|
my( $left, $mid, $right ) = @previous;
|
|
push @new,
|
|
( $left && $mid && ! $right )
|
|
|| ( !$left && $mid && $right )
|
|
|| ( $left && !$mid && !$right )
|
|
|| ( !$left && !$mid && $right );
|
|
shift @previous;
|
|
}
|
|
push @levels, \@new;
|
|
|
|
$sum += sum map { !$_ } map { @$_ } shift @levels;
|
|
}
|
|
|
|
|
|
say sum $sum, map { !$_ } map { @$_ } @levels;
|