aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark A <andemark@a-iot1t.uch.ad.pvt>2021-08-02 03:16:14 -0600
committerMark A <andemark@a-iot1t.uch.ad.pvt>2021-08-02 03:16:14 -0600
commit104dd682d296f7ab6aedafd35a2d86f16a7a79b5 (patch)
tree8f243fcc38dab2fa41f91957a40d6fe5d3b1f173
parent07cf10cea7d97f529a19e00ea9a1f902fc74177e (diff)
downloadperlweeklychallenge-club-104dd682d296f7ab6aedafd35a2d86f16a7a79b5.tar.gz
perlweeklychallenge-club-104dd682d296f7ab6aedafd35a2d86f16a7a79b5.tar.bz2
perlweeklychallenge-club-104dd682d296f7ab6aedafd35a2d86f16a7a79b5.zip
ch-2.raku
-rw-r--r--challenge-124/mark-anderson/raku/ch-2.raku18
1 files changed, 18 insertions, 0 deletions
diff --git a/challenge-124/mark-anderson/raku/ch-2.raku b/challenge-124/mark-anderson/raku/ch-2.raku
new file mode 100644
index 0000000000..6762d2c45e
--- /dev/null
+++ b/challenge-124/mark-anderson/raku/ch-2.raku
@@ -0,0 +1,18 @@
+#!/usr/bin/env raku
+
+say tug-of-war(10, 20 ... 100);
+say tug-of-war(10, -15, 20, 30, -25, 0, 5, 40, -5);
+
+sub tug-of-war(+$list)
+{
+ my $n = $list.elems div 2;
+
+ my %h = $list.combinations($n).map(-> @a
+ {
+ my @b = ($list (-) @a).keys;
+
+ abs(@b.sum - @a.sum) => @a ~ ' ' ~ @b;
+ });
+
+ .head($n), .tail(* - $n) with %h.min.value.split(/\s/).cache;
+}