aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--challenge-327/ash/raku/ch-1.raku10
-rw-r--r--challenge-327/ash/raku/ch-2.raku13
-rw-r--r--challenge-327/ash/raku/ch-2a.raku12
3 files changed, 35 insertions, 0 deletions
diff --git a/challenge-327/ash/raku/ch-1.raku b/challenge-327/ash/raku/ch-1.raku
new file mode 100644
index 0000000000..74723abdc5
--- /dev/null
+++ b/challenge-327/ash/raku/ch-1.raku
@@ -0,0 +1,10 @@
+# Task 1 of the Weekly Challenge 327
+# https://theweeklychallenge.org/blog/perl-weekly-challenge-327/#TASK1
+
+say missing-numbers(1, 2, 1, 3, 2, 5); # 4, 6
+say missing-numbers(1, 1, 1); # 2, 3
+say missing-numbers(2, 2, 1); # 3
+
+sub missing-numbers(*@data) {
+ (1 .. @data.elems) (-) @data
+}
diff --git a/challenge-327/ash/raku/ch-2.raku b/challenge-327/ash/raku/ch-2.raku
new file mode 100644
index 0000000000..6946b5f2e7
--- /dev/null
+++ b/challenge-327/ash/raku/ch-2.raku
@@ -0,0 +1,13 @@
+# Task 2 of the Weekly Challenge 327
+# https://theweeklychallenge.org/blog/perl-weekly-challenge-327/#TASK2
+
+say mad(4, 1, 2, 3); # ((4 3) (1 2) (2 3))
+say mad(1, 3, 7, 11, 15); # ((1 3))
+say mad(1, 5, 3, 8); # ((1 3) (5 3))
+
+sub mad(*@data) {
+ my @pairs = @data.combinations(2);
+ my $min_diff = min(@pairs.map: {abs(.[0] - .[1])});
+
+ return @pairs.grep: {abs(.[0] - .[1]) == $min_diff};
+}
diff --git a/challenge-327/ash/raku/ch-2a.raku b/challenge-327/ash/raku/ch-2a.raku
new file mode 100644
index 0000000000..1ef1f651a8
--- /dev/null
+++ b/challenge-327/ash/raku/ch-2a.raku
@@ -0,0 +1,12 @@
+# Task 2 of the Weekly Challenge 327
+# https://theweeklychallenge.org/blog/perl-weekly-challenge-327/#TASK2
+
+say mad(4, 1, 2, 3); # [(4 3) (1 2) (2 3)]
+say mad(1, 3, 7, 11, 15); # [(1 3)]
+say mad(1, 5, 3, 8); # [(1 3) (5 3)]
+
+sub mad(*@data) {
+ my $classification = @data.combinations(2).classify: {abs(.[0] - .[1])};
+
+ return ($classification.first: *.key == $classification.keys.min).value;
+}