diff options
| author | 冯昶 <fengchang@novel-supertv.com> | 2024-03-11 11:48:41 +0800 |
|---|---|---|
| committer | 冯昶 <fengchang@novel-supertv.com> | 2024-03-11 11:48:41 +0800 |
| commit | e721971cb16b00e3877f484017d8b8001f53edaf (patch) | |
| tree | e0bd112f634ea25d49a7f33deb1fbeb99c762f86 | |
| parent | 8d8f9f052114a2b03b2b652a70ef4e75428f8239 (diff) | |
| download | perlweeklychallenge-club-e721971cb16b00e3877f484017d8b8001f53edaf.tar.gz perlweeklychallenge-club-e721971cb16b00e3877f484017d8b8001f53edaf.tar.bz2 perlweeklychallenge-club-e721971cb16b00e3877f484017d8b8001f53edaf.zip | |
challenge 260, raku solutions
| -rwxr-xr-x | challenge-260/feng-chang/raku/ch-1.raku | 6 | ||||
| -rwxr-xr-x | challenge-260/feng-chang/raku/ch-2.raku | 5 | ||||
| -rwxr-xr-x | challenge-260/feng-chang/raku/test.raku | 24 |
3 files changed, 35 insertions, 0 deletions
diff --git a/challenge-260/feng-chang/raku/ch-1.raku b/challenge-260/feng-chang/raku/ch-1.raku new file mode 100755 index 0000000000..5a4a5a375b --- /dev/null +++ b/challenge-260/feng-chang/raku/ch-1.raku @@ -0,0 +1,6 @@ +#!/bin/env raku + +unit sub MAIN(*@ints); + +my @a = @ints.Bag.values; +put +(+@a.unique == +@a); diff --git a/challenge-260/feng-chang/raku/ch-2.raku b/challenge-260/feng-chang/raku/ch-2.raku new file mode 100755 index 0000000000..12823d8afe --- /dev/null +++ b/challenge-260/feng-chang/raku/ch-2.raku @@ -0,0 +1,5 @@ +#!/bin/env raku + +unit sub MAIN(Str:D $w); + +put $w.comb.permutations».join.unique.sort.first($w, :k) + 1; diff --git a/challenge-260/feng-chang/raku/test.raku b/challenge-260/feng-chang/raku/test.raku new file mode 100755 index 0000000000..49b576a879 --- /dev/null +++ b/challenge-260/feng-chang/raku/test.raku @@ -0,0 +1,24 @@ +#!/bin/env raku + +# The Weekly Challenge 260 +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, Unique Occurrences +pwc-test './ch-1.raku', <1 2 2 1 1 3>, 1, 'Unique Occurrences: (1,2,2,1,1,3) => 1'; +pwc-test './ch-1.raku', <1 2 3>, 0, 'Unique Occurrences: (1,2,3) => 0'; +pwc-test './ch-1.raku', <-- -2 0 1 -2 1 1 0 1 -2 9>, 1, 'Unique Occurrences: (-2,0,1,-2,1,1,0,1,-2,9) => 1'; + +# Task 2, Dictionary Rank +pwc-test './ch-2.raku', 'CAT', 3, 'Dictionary Rank: CAT => 3'; +pwc-test './ch-2.raku', 'GOOGLE', 88, 'Dictionary Rank: GOOGLE => 88'; +pwc-test './ch-2.raku', 'SECRET', 255, 'Dictionary Rank: SECRET => 255'; |
