aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMohammad S Anwar <Mohammad.Anwar@yahoo.com>2023-04-30 10:27:14 +0100
committerGitHub <noreply@github.com>2023-04-30 10:27:14 +0100
commit367b0c5ad022e2c4fdb00f8fd96c6f69ca09e6db (patch)
tree5bd31274fd40eb012cf01578d78946ae27b1b583
parent77d0dc16c694c25f5bd6c1e8f4978fe53493225c (diff)
parent23598bd553adbdbb7454be84f8754936b53bcdfc (diff)
downloadperlweeklychallenge-club-367b0c5ad022e2c4fdb00f8fd96c6f69ca09e6db.tar.gz
perlweeklychallenge-club-367b0c5ad022e2c4fdb00f8fd96c6f69ca09e6db.tar.bz2
perlweeklychallenge-club-367b0c5ad022e2c4fdb00f8fd96c6f69ca09e6db.zip
Merge pull request #7985 from andemark/challenge-214-Raku
Challenge 214 raku
-rw-r--r--challenge-214/mark-anderson/raku/ch-1.raku12
1 files changed, 8 insertions, 4 deletions
diff --git a/challenge-214/mark-anderson/raku/ch-1.raku b/challenge-214/mark-anderson/raku/ch-1.raku
index fe4c92d8e4..149a1ee75e 100644
--- a/challenge-214/mark-anderson/raku/ch-1.raku
+++ b/challenge-214/mark-anderson/raku/ch-1.raku
@@ -7,12 +7,16 @@ is rank-score(<3 5 4 2>), <B G S 4>;
is rank-score(<2 5 2 1 7 5 1>), <4 S 4 6 G S 6>;
is rank-score(<20 76 15 55 76 15 20 20 15 20 20>), <4 G 9 B G 9 4 4 9 4 4>;
-sub rank-score($list)
+multi rank-score($list where .elems == 1) { 'G' }
+
+multi rank-score($list)
{
my $b = $list.Bag;
- my @a = [\+] flat 1, $b.sort(-*.key)>>.value;
- @a .= map({ <Nil G S B>[$_] or $_ });
+ my @k = $b.keys.sort(-*);
+ my @v = [\+] flat 1, $b{@k};
+
+ @v[^3] .= map({ <Nil G S B>[$_] or $_ });
+ my %h = @k Z=> @v;
- my %h = $b.keys.sort(-*) Z=> @a;
$list.map({ %h{$_} })
}