aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMohammad Sajid Anwar <Mohammad.Anwar@yahoo.com>2024-05-14 13:44:25 +0100
committerGitHub <noreply@github.com>2024-05-14 13:44:25 +0100
commitd5b7ee8bb0630029db887240814e620092e941a2 (patch)
treed68c8ecbfdf21e9cc3e2c2be58baca2378458aa4
parentfd7d4c9e131e93454378cb7147b40b442c6adbe3 (diff)
parentcea4578c256a61ed75d194d2b0de0c4566376392 (diff)
downloadperlweeklychallenge-club-d5b7ee8bb0630029db887240814e620092e941a2.tar.gz
perlweeklychallenge-club-d5b7ee8bb0630029db887240814e620092e941a2.tar.bz2
perlweeklychallenge-club-d5b7ee8bb0630029db887240814e620092e941a2.zip
Merge pull request #10085 from andemark/challenge-269
Challenge 269 Solutions (Raku)
-rw-r--r--challenge-269/mark-anderson/raku/ch-1.raku11
-rw-r--r--challenge-269/mark-anderson/raku/ch-2.raku42
2 files changed, 53 insertions, 0 deletions
diff --git a/challenge-269/mark-anderson/raku/ch-1.raku b/challenge-269/mark-anderson/raku/ch-1.raku
new file mode 100644
index 0000000000..4bf4381d80
--- /dev/null
+++ b/challenge-269/mark-anderson/raku/ch-1.raku
@@ -0,0 +1,11 @@
+#!/usr/bin/env raku
+use Test;
+
+ok bitwise-or(1,2,3,4,5);
+ok bitwise-or(2,3,8,16);
+nok bitwise-or(1,2,5,7,9);
+
+sub bitwise-or(*@ints)
+{
+ @ints ~~ m:2nd/ << (<.digit>+) >> <?{ $0 %% 2 }> /
+}
diff --git a/challenge-269/mark-anderson/raku/ch-2.raku b/challenge-269/mark-anderson/raku/ch-2.raku
new file mode 100644
index 0000000000..10ba8b8f39
--- /dev/null
+++ b/challenge-269/mark-anderson/raku/ch-2.raku
@@ -0,0 +1,42 @@
+#!/usr/bin/env raku
+use Test;
+
+is-deeply distribute-elements(2,1,3,4,5), [2,3,4,5,1];
+is-deeply distribute-elements(3,2,4), [3,4,2];
+is-deeply distribute-elements(5,4,3,8), [5,3,4,8];
+
+# I was going to try something like this
+#
+# while @ints
+# {
+# my $k = @ints.first(* < @arr2.tail, :k) // @ints.end;
+# @arr1.append: @ints.splice(0, $k+1);
+# :(@arr1, @arr2) := (@arr2, @arr1)
+# }
+#
+# but for some reason I get an error swapping inside the while loop.
+# Swapping the arrays works outside of the loop.
+# https://rakudoweekly.blog/2022/06/20/2022-25-we-will-raku/
+
+sub distribute-elements(*@ints)
+{
+ my @arr1 = @ints.shift;
+ my @arr2 = @ints.shift;
+
+ while @ints
+ {
+ if @arr1.tail > @arr2.tail
+ {
+ my $k = @ints.first(* < @arr2.tail, :k) // @ints.end;
+ @arr1.append: @ints.splice(0, $k+1)
+ }
+
+ else
+ {
+ my $k = @ints.first(* < @arr1.tail, :k) // @ints.end;
+ @arr2.append: @ints.splice(0, $k+1)
+ }
+ }
+
+ @arr1.append: @arr2
+}