summaryrefslogtreecommitdiff
path: root/01.pl
blob: 615f00418a2051cecb1e725291e506f7b3d67043 (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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#!/usr/bin/env perl
use strict;
use warnings;

use File::Slurp;

my $h = {
  one   => 1,
  two   => 2,
  three => 3,
  four  => 4,
  five  => 5,
  six   => 6,
  seven => 7,
  eight => 8,
  nine  => 9
};

my ( $o, $t ) = ( 0, 0 );

foreach ( read_file( '01.txt' ) ) {
  my ($f, $l) = (0, 0);
  foreach my $c ( split //, $_ ) {
    $c !~ /\d/ && next;
    $f ? $l = $c : $f = $c;
    $l = $l ? $l : $f;
  }
  $o += $f * 10 + $l;
}

print($o . "\n");

foreach ( read_file('01.txt') ) {
  my ( $f, $l, $i, $s ) = ( 0, 0, -1, 0 );
  foreach my $c ( split //, $_ ) {
    $i++;
    if ($s) { $s--; next; }

    if ( $c =~ /\d/ ) {
      $f ? $l = $c : $f = $c;
      $l = $l ? $l : $f;
      next;
    }

    foreach my $k ( keys %$h ) {
      if ( substr( $_, $i - 1, length($k) ) eq $k ) {
        my $b = $h->{$k};
        $s = length($k) - 2;
        $f ? $l = $b : $f = $b;
        $l = $l ? $l : $f;
        last;
      }
    }
  }
  $t += $f * 10 + $l;
}

print($t . "\n");