diff options
| author | Mark <53903062+andemark@users.noreply.github.com> | 2023-04-26 10:44:02 +0000 |
|---|---|---|
| committer | Mark <53903062+andemark@users.noreply.github.com> | 2023-04-26 10:44:02 +0000 |
| commit | 088c13928eb9de940b85234ed243f1e152df17c6 (patch) | |
| tree | 5c0a84c4f7d7421fc8750e134f522430538dd450 | |
| parent | 05c74535ed438cd5875cff7acc9df7091c4df68a (diff) | |
| download | perlweeklychallenge-club-088c13928eb9de940b85234ed243f1e152df17c6.tar.gz perlweeklychallenge-club-088c13928eb9de940b85234ed243f1e152df17c6.tar.bz2 perlweeklychallenge-club-088c13928eb9de940b85234ed243f1e152df17c6.zip | |
ch-2.raku do-over
| -rw-r--r-- | challenge-214/mark-anderson/raku/ch-2.raku | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/challenge-214/mark-anderson/raku/ch-2.raku b/challenge-214/mark-anderson/raku/ch-2.raku new file mode 100644 index 0000000000..0908191003 --- /dev/null +++ b/challenge-214/mark-anderson/raku/ch-2.raku @@ -0,0 +1,36 @@ +#!/usr/bin/env raku +use Adverb::Eject; +use Test; + +is collect-points(<2 4 3 3 3 4 5 4 2>), 23; +is collect-points(<1 2 2 2 2 1>), 20; +is collect-points(1), 1; +is collect-points(<2 2 2 1 1 2 2 2>), 40; +is collect-points(<1 1 1 25 3 25 3 25 44 9 25 44 25 5 25 5 25 1 1 1>), 92; + +sub collect-points(*@a) +{ + sum gather while @a + { + my $c = @a.pairs.classify({ .value }, :as{ .key }); + my $p = $c.first({ consecutive(.value) }); + + if $p + { + @a[ $c{$p.key} ]:eject + } + + else + { + $p = $c.classify({ .key }, :as{ .value.elems }).minpairs.head; + @a[ $c{$p.key}.head ]:eject + } + + take $p.value.elems ** 2 + } +} + +sub consecutive(@a) +{ + .tail - .head == .end and [<] $_ given @a +} |
