aboutsummaryrefslogtreecommitdiff
path: root/challenge-331
diff options
context:
space:
mode:
authorJan Krňávek <Jan.Krnavek@gmail.com>2025-07-27 13:44:48 +0200
committerJan Krňávek <Jan.Krnavek@gmail.com>2025-07-27 13:44:48 +0200
commitcfd71cfe3ac76ea9fcd17d9eb783e7da4f3c8c2f (patch)
tree1aa59b30577bc7a75cc10ba63056fe896747c2ab /challenge-331
parent1ff2c9796a511d63231d3757acb27e4046a91fb2 (diff)
downloadperlweeklychallenge-club-cfd71cfe3ac76ea9fcd17d9eb783e7da4f3c8c2f.tar.gz
perlweeklychallenge-club-cfd71cfe3ac76ea9fcd17d9eb783e7da4f3c8c2f.tar.bz2
perlweeklychallenge-club-cfd71cfe3ac76ea9fcd17d9eb783e7da4f3c8c2f.zip
solutions week 331
Diffstat (limited to 'challenge-331')
-rw-r--r--challenge-331/wambash/raku/ch-1.raku20
-rw-r--r--challenge-331/wambash/raku/ch-2.raku27
2 files changed, 47 insertions, 0 deletions
diff --git a/challenge-331/wambash/raku/ch-1.raku b/challenge-331/wambash/raku/ch-1.raku
new file mode 100644
index 0000000000..b4afda16ca
--- /dev/null
+++ b/challenge-331/wambash/raku/ch-1.raku
@@ -0,0 +1,20 @@
+#!/usr/bin/env raku
+
+sub last-word ($str) {
+ $str
+ andthen .words
+ andthen .tail
+ andthen .chars
+}
+
+multi MAIN (Bool :test($)!) {
+ use Test;
+ is last-word('The Weekly Challenge'), 9;
+ is last-word(' Hello World '), 5;
+ is last-word('Let\'s begin the fun' ), 3;
+ done-testing;
+}
+
+multi MAIN ($str) {
+ say last-word $str;
+}
diff --git a/challenge-331/wambash/raku/ch-2.raku b/challenge-331/wambash/raku/ch-2.raku
new file mode 100644
index 0000000000..4ac7c43499
--- /dev/null
+++ b/challenge-331/wambash/raku/ch-2.raku
@@ -0,0 +1,27 @@
+#!/usr/bin/env raku
+
+multi buddy-strings ($source, $target where {$source eq $target}) {
+ my @letters = $source.comb;
+ @letters Zeq @letters.skip
+ andthen .any
+}
+
+multi buddy-strings ($source, $target) {
+ $source.comb Z, $target.comb
+ andthen .grep: { .[0] !eq .[1] }, :v
+ andthen { .elems == 2 and all .[0] Zeq .[1].reverse}
+}
+
+multi MAIN (Bool :test($)!) {
+ use Test;
+ is buddy-strings('fuck','fcuk'), True;
+ is buddy-strings('love','love'), False;
+ is buddy-strings('fodo','food'), True;
+ is buddy-strings('fodo','fooo'), False;
+ is buddy-strings('feed','feed'), True;
+ done-testing;
+}
+
+multi MAIN ($source, $target) {
+ say so buddy-strings $source, $target;
+}