diff options
| author | Mohammad Sajid Anwar <Mohammad.Anwar@yahoo.com> | 2025-08-29 22:40:32 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-08-29 22:40:32 +0100 |
| commit | 6ceedff951073181fc01b5ea67f8dd843e1cea86 (patch) | |
| tree | 629bf161b9acb900f17048a3cfa223597fb0cfe7 | |
| parent | 4dc60a91179e57d3a4f857503d721ab50652d442 (diff) | |
| parent | 9c3f465117e99a61e20d415d9f9e01acb634f461 (diff) | |
| download | perlweeklychallenge-club-6ceedff951073181fc01b5ea67f8dd843e1cea86.tar.gz perlweeklychallenge-club-6ceedff951073181fc01b5ea67f8dd843e1cea86.tar.bz2 perlweeklychallenge-club-6ceedff951073181fc01b5ea67f8dd843e1cea86.zip | |
Merge pull request #12591 from arnesom/challenge-336-arne-sommer
week 336 Arne Sommer
| -rw-r--r-- | challenge-336/arne-sommer/blog.txt | 1 | ||||
| -rwxr-xr-x | challenge-336/arne-sommer/raku/ch-1.raku | 50 | ||||
| -rwxr-xr-x | challenge-336/arne-sommer/raku/ch-2.raku | 22 | ||||
| -rwxr-xr-x | challenge-336/arne-sommer/raku/equal-group | 15 | ||||
| -rwxr-xr-x | challenge-336/arne-sommer/raku/equal-group-ordered | 50 | ||||
| -rwxr-xr-x | challenge-336/arne-sommer/raku/equal-group-prime | 28 | ||||
| -rwxr-xr-x | challenge-336/arne-sommer/raku/final-score | 22 |
7 files changed, 188 insertions, 0 deletions
diff --git a/challenge-336/arne-sommer/blog.txt b/challenge-336/arne-sommer/blog.txt new file mode 100644 index 0000000000..aa55fe14e7 --- /dev/null +++ b/challenge-336/arne-sommer/blog.txt @@ -0,0 +1 @@ +https://raku-musings.com/equally-final.html
\ No newline at end of file diff --git a/challenge-336/arne-sommer/raku/ch-1.raku b/challenge-336/arne-sommer/raku/ch-1.raku new file mode 100755 index 0000000000..2ffee70865 --- /dev/null +++ b/challenge-336/arne-sommer/raku/ch-1.raku @@ -0,0 +1,50 @@ +#! /usr/bin/env raku + +unit sub MAIN (*@ints where @ints.elems > 0 && all(@ints) ~~ Int, + :v(:$verbose)); + +my @freq; +my $curr = @ints[0]; +my $freq = 1; + +for @ints[1 .. Inf] -> $int +{ + if $int == $curr + { + $freq++; + } + else + { + @freq.push: $freq; + $curr = $int; + $freq = 1; + } +} + +@freq.push: $freq; + +my $min = @freq.min; + +if $verbose +{ + say ": Frequency: { @freq.join(", ") }"; + say ": Group size (min freq): $min"; +} + +for 2 .. $min -> $i +{ + next unless $i.is-prime; + + if all(@freq) %% $i + { + if $verbose + { + say ": Group size (prime): $i"; + say ": Grouped: { @ints>>.Int.rotor($i).raku }"; + } + say 'true'; + exit; + } +} + +say 'false';
\ No newline at end of file diff --git a/challenge-336/arne-sommer/raku/ch-2.raku b/challenge-336/arne-sommer/raku/ch-2.raku new file mode 100755 index 0000000000..02d5cebe5e --- /dev/null +++ b/challenge-336/arne-sommer/raku/ch-2.raku @@ -0,0 +1,22 @@ +#! /usr/bin/env raku + +unit sub MAIN (*@scores where @scores.elems > 0, + :v(:$verbose)); + +my @processed; +my $round = 1; + +for @scores -> $score +{ + given $score + { + when Int { @processed.push: $score; } + when '+' { @processed.push: @processed[*-1] + @processed[*-2]; } + when 'C' { @processed.pop; } + when 'D' { @processed.push: @processed[*-1] * 2; } + default { die "Illegal score $score"; } + } + say ": Round { $round++ }: Value:$score -> Scores: { @processed.join(",") }" if $verbose; +} + +say @processed.sum;
\ No newline at end of file diff --git a/challenge-336/arne-sommer/raku/equal-group b/challenge-336/arne-sommer/raku/equal-group new file mode 100755 index 0000000000..3ad608ae43 --- /dev/null +++ b/challenge-336/arne-sommer/raku/equal-group @@ -0,0 +1,15 @@ +#! /usr/bin/env raku + +unit sub MAIN (*@ints where @ints.elems > 0 && all(@ints) ~~ Int, + :v(:$verbose)); + +my $bag = @ints>>.Int.Bag; +my $min = $bag.values.min; + +if $verbose +{ + say ": Bag: { $bag.raku }"; + say ": Group size (min freq): $min"; +} + +say so $min > 1 && all($bag.values) %% $min; diff --git a/challenge-336/arne-sommer/raku/equal-group-ordered b/challenge-336/arne-sommer/raku/equal-group-ordered new file mode 100755 index 0000000000..2ffee70865 --- /dev/null +++ b/challenge-336/arne-sommer/raku/equal-group-ordered @@ -0,0 +1,50 @@ +#! /usr/bin/env raku + +unit sub MAIN (*@ints where @ints.elems > 0 && all(@ints) ~~ Int, + :v(:$verbose)); + +my @freq; +my $curr = @ints[0]; +my $freq = 1; + +for @ints[1 .. Inf] -> $int +{ + if $int == $curr + { + $freq++; + } + else + { + @freq.push: $freq; + $curr = $int; + $freq = 1; + } +} + +@freq.push: $freq; + +my $min = @freq.min; + +if $verbose +{ + say ": Frequency: { @freq.join(", ") }"; + say ": Group size (min freq): $min"; +} + +for 2 .. $min -> $i +{ + next unless $i.is-prime; + + if all(@freq) %% $i + { + if $verbose + { + say ": Group size (prime): $i"; + say ": Grouped: { @ints>>.Int.rotor($i).raku }"; + } + say 'true'; + exit; + } +} + +say 'false';
\ No newline at end of file diff --git a/challenge-336/arne-sommer/raku/equal-group-prime b/challenge-336/arne-sommer/raku/equal-group-prime new file mode 100755 index 0000000000..cdc74eef4c --- /dev/null +++ b/challenge-336/arne-sommer/raku/equal-group-prime @@ -0,0 +1,28 @@ +#! /usr/bin/env raku + +unit sub MAIN (*@ints where @ints.elems > 0 && all(@ints) ~~ Int, + :v(:$verbose)); + + +my $bag = @ints>>.Int.Bag; +my $min = $bag.values.min; + +if $verbose +{ + say ": Bag: { $bag.raku }"; + say ": Group size (min freq): $min"; +} + +for 2 .. $min -> $i +{ + next unless $i.is-prime; + + if $i > 1 && all($bag.values) %% $i + { + say ": Group size (prime): $i"; + say 'true'; + exit; + } +} + +say 'false';
\ No newline at end of file diff --git a/challenge-336/arne-sommer/raku/final-score b/challenge-336/arne-sommer/raku/final-score new file mode 100755 index 0000000000..02d5cebe5e --- /dev/null +++ b/challenge-336/arne-sommer/raku/final-score @@ -0,0 +1,22 @@ +#! /usr/bin/env raku + +unit sub MAIN (*@scores where @scores.elems > 0, + :v(:$verbose)); + +my @processed; +my $round = 1; + +for @scores -> $score +{ + given $score + { + when Int { @processed.push: $score; } + when '+' { @processed.push: @processed[*-1] + @processed[*-2]; } + when 'C' { @processed.pop; } + when 'D' { @processed.push: @processed[*-1] * 2; } + default { die "Illegal score $score"; } + } + say ": Round { $round++ }: Value:$score -> Scores: { @processed.join(",") }" if $verbose; +} + +say @processed.sum;
\ No newline at end of file |
