aboutsummaryrefslogtreecommitdiff
path: root/challenge-077/e-choroba/perl/ch-2.pl
blob: ebf221f3bcddaa1f3a6f659beeca99f0731bd3ec (plain)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#!/usr/bin/perl
use warnings;
use strict;

my $NO_X = qr/[^X] [^X] [^X]/;

sub lonely_x {
    my ($input) = @_;

    my ($previous, @check);
    my $count = 0;
    my $verify = sub {
        for my $ch (@check) {
            $count += substr($_[0], $ch - 2, 5) =~ $NO_X;
        }
    };

    open my $in, '<', \$input;
    while (<$in>) {
        $previous //= ' ' x length;
        $verify->($_);
        @check = ();

        while (/(?=[^X] X [^X])/g) {
            my $pos = pos;
            push @check, $pos + 2 if substr($previous, $pos, 5) =~ $NO_X;
        }
        $previous = $_;
    }
    $verify->(' ' x length $previous);

    return $count
}

use Test::More tests => 5;

is lonely_x(<< '__'),
[ O O X ]
[ X O X ]
[ X O O ]
__
0, 'None found';

is lonely_x(<< '__'),
[ O O X ]
[ X O O ]
[ X O O ]
__
1, 'Example 1';

is lonely_x(<< '__'),
[ O O X O ]
[ X O O O ]
[ X O O X ]
[ O X O O ]
__
2, 'Example 2';

is lonely_x(<< '__'),
[ O O O X O X X ]
[ X O O O O O O ]
[ O O O O X O X ]
[ O O X O O O O ]
[ O X O O X O O ]
[ X O O O X O X ]
__
5, 'Five';

is lonely_x(<< '__'),
[ X X X X O X O O O O O X X X X X O O O O O O X X X X O O X X X O O O O X O O ]
[ O O O O O O X O X O X O O O O X O X X X X O O X X X X O X O X O O X O O X X ]
[ O X O X X O O O O O O X X X O O O X O X O X X X O O X O O O O X O X X X O X ]
[ O X O X X O O O O X O X O O X X X O X O O X O X O X O O O X X O X O X X X X ]
[ O O X X X O O O X O X O O X O X O O X X O X O X X O X X O X X O O O O O O X ]
[ O O O X X X O O O O O O O X O X X O X O O O O O X X X O X X O O O O X O O O ]
[ O X X X X X O O X O X X O O X O X X X O X O O X O X O X X O X O O X X X X X ]
[ O O O X O X X X O O X X O X X O X O O O O X O X X X O X X O O X O O O X O O ]
[ X O X X X O O O O O X O X O O O O O O X X O X O O O O O X O O O X O X O O X ]
[ X X X O O O X O O O O X O X O X O X O O X X X O X X O O X X X O O O O O O O ]
[ X O X O X O X O X X O O X X X X X X X X X X X O X X O X O O O X O O O X O O ]
[ X O X O O X O X X O X O X O X X O X X O O X O O O X X X O O O X X X O X O X ]
[ O X O O X X X O X X O O O O O X O O O X O O O X X X X O X X O O X X O O X O ]
[ X O O O X O X X O O X O O O X X O X O O O X X X O X O X O O O X O X O X X O ]
[ X X X X X X X O X O X O O O X O O X O X X X X O O O O X X X O O O X X O X X ]
[ O X X O O X X X O O X X O X O O O X O X O X X O O X O O X O O O O O O O O X ]
[ O X O X O O O X O X O X O O O O X X X O X X O O X X O X X X O O X O X X O O ]
[ O O X O X O O X X X X O O X O X O O X O X O X X X O X X O X X O O X X X O X ]
[ O X X O O O O X O O O O O X X O O X X O X O X O X O O X O O X O X O X O X O ]
[ O X X O X X X X O O X X X X O X O O X O X O X O O O X O X X X X O O X X X X ]
[ O O O O O O O X X X X O O X O O X X O O O X O O X O X O X O O X X O O O O X ]
[ O O X O X O O X X X O O X X X X O O X X X