aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMohammad Sajid Anwar <Mohammad.Anwar@yahoo.com>2025-09-15 10:01:09 +0100
committerGitHub <noreply@github.com>2025-09-15 10:01:09 +0100
commit108fd3b6c42e3ce2dfbc62a6745b8dcd4b914680 (patch)
tree34fccf12206eb88f10148945311aaf9a978144ac
parent1c5dfb8a44c50660fcbc4c4e6eae3a74555931db (diff)
parentf646cf5f389a9d4b47415b905340e11d0d3b8c3b (diff)
downloadperlweeklychallenge-club-108fd3b6c42e3ce2dfbc62a6745b8dcd4b914680.tar.gz
perlweeklychallenge-club-108fd3b6c42e3ce2dfbc62a6745b8dcd4b914680.tar.bz2
perlweeklychallenge-club-108fd3b6c42e3ce2dfbc62a6745b8dcd4b914680.zip
Merge pull request #12676 from seaker/master
challenge 339, raku solutions
-rwxr-xr-xchallenge-339/feng-chang/raku/ch-1.raku5
-rwxr-xr-xchallenge-339/feng-chang/raku/ch-2.raku5
-rwxr-xr-xchallenge-339/feng-chang/raku/test.raku28
3 files changed, 38 insertions, 0 deletions
diff --git a/challenge-339/feng-chang/raku/ch-1.raku b/challenge-339/feng-chang/raku/ch-1.raku
new file mode 100755
index 0000000000..568015e151
--- /dev/null
+++ b/challenge-339/feng-chang/raku/ch-1.raku
@@ -0,0 +1,5 @@
+#!/bin/env raku
+
+unit sub MAIN(*@ints);
+
+put @ints.combinations(4).map(-> @a { (^4).combinations(2).map(-> @b { abs(([*] @a[@b]) - [*] @a[(^4 (-) @b).keys]) }) }).flat.max;
diff --git a/challenge-339/feng-chang/raku/ch-2.raku b/challenge-339/feng-chang/raku/ch-2.raku
new file mode 100755
index 0000000000..ed734a5b9b
--- /dev/null
+++ b/challenge-339/feng-chang/raku/ch-2.raku
@@ -0,0 +1,5 @@
+#!/bin/env raku
+
+unit sub MAIN(*@ints);
+
+put ([\+] 0,|@ints).max;
diff --git a/challenge-339/feng-chang/raku/test.raku b/challenge-339/feng-chang/raku/test.raku
new file mode 100755
index 0000000000..592d8dd441
--- /dev/null
+++ b/challenge-339/feng-chang/raku/test.raku
@@ -0,0 +1,28 @@
+#!/bin/env raku
+
+# The Weekly Challenge 339
+use Test;
+
+sub pwc-test(Str:D $script, Bool :$deeply? = False, *@input) {
+ my ($expect, $assertion) = @input.splice(*-2, 2);
+ my $p = run $script, |@input, :out;
+ if $deeply {
+ is-deeply $p.out.slurp(:close).chomp.words.Bag, $expect, $assertion;
+ } else {
+ is $p.out.slurp(:close).chomp, $expect, $assertion;
+ }
+}
+
+# Task 1, Max Diff
+pwc-test './ch-1.raku', <5 9 3 4 6>, 42, 'Max Diff: (5,9,3,4,6) => 42';
+pwc-test './ch-1.raku', <1 -2 3 -4>, 10, 'Max Diff: (1,-2,3,-4) => 10';
+pwc-test './ch-1.raku', <-- -3 -1 -2 -4>, 10, 'Max Diff: (-3,-1,-2,-4) => 10';
+pwc-test './ch-1.raku', <10 2 0 5 1>, 50, 'Max Diff: (10,2,0,5,1) => 50';
+pwc-test './ch-1.raku', <7 8 9 10 10>, 44, 'Max Diff: (7,8,9,10,10) => 44';
+
+# Task 2, Peak Point
+pwc-test './ch-2.raku', <-- -5 1 5 -9 2>, 1, 'Peak Point: (-5,1,5,-9,2) => 1';
+pwc-test './ch-2.raku', <10 10 10 -25>, 30, 'Peak Point: (10,10,10,-25) => 30';
+pwc-test './ch-2.raku', <3 -4 2 5 -6 1>, 6, 'Peak Point: (3,-4,2,5,-6,1) => 6';
+pwc-test './ch-2.raku', <-- -1 -2 -3 -4>, 0, 'Peak Point: (-1,-2,-3,-4) => 0';
+pwc-test './ch-2.raku', <-- -10 15 5>, 10, 'Peak Point: (-10,15,5) => 10';