aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJan Krňávek <Jan.Krnavek@gmail.com>2024-02-18 14:38:50 +0100
committerJan Krňávek <Jan.Krnavek@gmail.com>2024-02-18 14:38:50 +0100
commitcaebc678b4842773e3517fdfa506badb4335bf94 (patch)
tree8054aad9597e11d7c35a06052af2ff8900f1f44e
parentea7a39e00664462772534988dd02a7b6e658afa2 (diff)
downloadperlweeklychallenge-club-caebc678b4842773e3517fdfa506badb4335bf94.tar.gz
perlweeklychallenge-club-caebc678b4842773e3517fdfa506badb4335bf94.tar.bz2
perlweeklychallenge-club-caebc678b4842773e3517fdfa506badb4335bf94.zip
solutions week 256
-rw-r--r--challenge-256/wambash/raku/ch-1.raku19
-rw-r--r--challenge-256/wambash/raku/ch-2.raku21
2 files changed, 40 insertions, 0 deletions
diff --git a/challenge-256/wambash/raku/ch-1.raku b/challenge-256/wambash/raku/ch-1.raku
new file mode 100644
index 0000000000..f39495c7eb
--- /dev/null
+++ b/challenge-256/wambash/raku/ch-1.raku
@@ -0,0 +1,19 @@
+#!/usr/bin/env raku
+
+sub maximum-pairs (+words) {
+ words.kv
+ andthen .map: -> $i, $w { [+] $w.flip «eq« words.skip: $i + 1 }\
+ andthen .sum
+}
+
+multi MAIN (Bool :test($)!) {
+ use Test;
+ is maximum-pairs(<ab de ed bc>),1;
+ is maximum-pairs(<aa ba cd ed>),0;
+ is maximum-pairs(<uv qp st vu mn pq>),2;
+ done-testing;
+}
+
+multi MAIN (+words) {
+ say maximum-pairs words
+}
diff --git a/challenge-256/wambash/raku/ch-2.raku b/challenge-256/wambash/raku/ch-2.raku
new file mode 100644
index 0000000000..90d80fcf51
--- /dev/null
+++ b/challenge-256/wambash/raku/ch-2.raku
@@ -0,0 +1,21 @@
+#!/usr/bin/env raku
+
+sub merge-strings (+string) {
+ string
+ andthen .map: *.comb
+ andthen roundrobin |$_, :slip
+ andthen .join
+}
+
+multi MAIN (Bool :test($)!) {
+ use Test;
+ is merge-strings(<abcd 1234>), 'a1b2c3d4';
+ is merge-strings('abc','12345'), 'a1b2c345';
+ is merge-strings(<abcde 123>), 'a1b2c3de';
+ is merge-strings(<abcde 123 AB>), 'a1Ab2Bc3de';
+ done-testing;
+}
+
+multi MAIN (+string) {
+ say merge-strings string
+}