aboutsummaryrefslogtreecommitdiff
path: root/challenge-196
diff options
context:
space:
mode:
authorMark <53903062+andemark@users.noreply.github.com>2022-12-19 10:57:11 +0000
committerMark <53903062+andemark@users.noreply.github.com>2022-12-19 10:57:11 +0000
commit93aa81cec3d670d325af56ec86d47adc2a677c2a (patch)
tree8c0334eef95c383e6c82c6499a383a56b1e73553 /challenge-196
parentd0495985bdee0af409e7301b6b37dd6fe063f4d7 (diff)
downloadperlweeklychallenge-club-93aa81cec3d670d325af56ec86d47adc2a677c2a.tar.gz
perlweeklychallenge-club-93aa81cec3d670d325af56ec86d47adc2a677c2a.tar.bz2
perlweeklychallenge-club-93aa81cec3d670d325af56ec86d47adc2a677c2a.zip
Challenge 196 Solutions (Raku)
Diffstat (limited to 'challenge-196')
-rw-r--r--challenge-196/mark-anderson/raku/ch-1.raku22
-rw-r--r--challenge-196/mark-anderson/raku/ch-2.raku28
2 files changed, 50 insertions, 0 deletions
diff --git a/challenge-196/mark-anderson/raku/ch-1.raku b/challenge-196/mark-anderson/raku/ch-1.raku
new file mode 100644
index 0000000000..7b844a207b
--- /dev/null
+++ b/challenge-196/mark-anderson/raku/ch-1.raku
@@ -0,0 +1,22 @@
+#!/usr/bin/env raku
+use Test;
+
+is-deeply pattern-acb(3,1,4,2), (1,4,2);
+is-deeply pattern-acb(1,2,3,4), ();
+is-deeply pattern-acb(1,3,2,4,6,5), (1,3,2);
+
+sub pattern-acb(+$list)
+{
+ for 0..$list-1 -> $a
+ {
+ for $a+1..$list-1 -> $b
+ {
+ for $b+1..$list-1 -> $c
+ {
+ return $list[$a,$b,$c] if $list[$a] < $list[$c] < $list[$b]
+ }
+ }
+ }
+
+ return ()
+}
diff --git a/challenge-196/mark-anderson/raku/ch-2.raku b/challenge-196/mark-anderson/raku/ch-2.raku
new file mode 100644
index 0000000000..64ead6051b
--- /dev/null
+++ b/challenge-196/mark-anderson/raku/ch-2.raku
@@ -0,0 +1,28 @@
+#!/usr/bin/env raku
+use Test;
+
+is-deeply range-list(1,3,4,5,7), ((3,5),);
+is-deeply range-list(1,2,3,6,7,9), ((1,3), (6,7));
+is-deeply range-list(0,1,2,4,5,6,8,9), ((0,2), (4,6), (8,9));
+
+sub range-list(+$list)
+{
+ my ($h, $t) = (0, 0);
+
+ my $a := gather for $list.rotor(2 => -1, :partial)
+ {
+ if .tail - .head == 1
+ {
+ $t++
+ }
+
+ else
+ {
+ take $h, $t;
+ $t++;
+ $h = $t;
+ }
+ }
+
+ $list[ $a.grep({ .head < .tail }) ]
+}