From 79992d64c429998957eeaf92886d367828ff150d Mon Sep 17 00:00:00 2001 From: Jörg Sommrey <28217714+jo-37@users.noreply.github.com> Date: Wed, 18 Jun 2025 22:44:41 +0200 Subject: Solution to task 1 --- challenge-326/jo-37/perl/ch-1.pl | 94 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 94 insertions(+) create mode 100755 challenge-326/jo-37/perl/ch-1.pl diff --git a/challenge-326/jo-37/perl/ch-1.pl b/challenge-326/jo-37/perl/ch-1.pl new file mode 100755 index 0000000000..35cbb6b366 --- /dev/null +++ b/challenge-326/jo-37/perl/ch-1.pl @@ -0,0 +1,94 @@ +#!/usr/bin/perl + +use v5.26; +use Test2::V0 -no_srand; +use Test2::Tools::Subtest 'subtest_streamed'; +use Getopt::Long; +use experimental 'signatures'; + +use DateTime::Format::Strptime; + +### Options and Arguments + +my ($tests, $examples, $verbose); +GetOptions( + 'examples!' => \$examples, + 'tests!' => \$tests, + 'verbose!' => \$verbose, +) or usage(); + +run_tests($examples, $tests); # tests do not return + +usage() unless @ARGV; + +sub usage { + die <<~EOS; + $0 - day of the year + + usage: $0 [-examples] [-tests] [YYYY-MM-DD] + + -examples + run the examples from the challenge + + -tests + run some tests + + YYYY-MM-DD + a date + + EOS +} + + +### Input and Output + +say day_of_year(shift); + + +### Implementation +# +# For details see: +# https://github.sommrey.de/the-bears-den/2025/06/18/ch-326.html#task-1 + +use constant YMD => DateTime::Format::Strptime->new(pattern => '%F', + on_error => 'croak'); + +sub day_of_year { + YMD->parse_datetime(shift)->day_of_year; +} + + +### Examples and Tests + +sub run_tests ($examples, $tests) { + return unless $examples || $tests; + + state sub run_example ($args, $expected, $name) { + my $result = day_of_year(@$args); + is $result, $expected, + "$name: (@$args) -> $expected"; + } + + plan 2; + + $examples ? subtest_streamed(examples => sub { + my @examples = ( + [['2025-02-02'], 33, 'example 1'], + [['2025-04-10'], 100, 'example 2'], + [['2025-09-07'], 250, 'example 3'], + ); + plan scalar @examples; + for (@examples) { + run_example @$_; + } + }) : pass 'skip examples'; + + $tests ? subtest_streamed(tests => sub { + plan 1; + like dies {day_of_year('2024-02-30')}, + qr/did not produce a valid date/, 'invalid date'; + + }) : pass 'skip tests'; + + exit; +} -- cgit From 9aa70d827196a8f56afef33164235d2fa9199649 Mon Sep 17 00:00:00 2001 From: Jörg Sommrey <28217714+jo-37@users.noreply.github.com> Date: Wed, 18 Jun 2025 22:44:55 +0200 Subject: Solution to task 2 --- challenge-326/jo-37/perl/ch-2.pl | 103 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 103 insertions(+) create mode 100755 challenge-326/jo-37/perl/ch-2.pl diff --git a/challenge-326/jo-37/perl/ch-2.pl b/challenge-326/jo-37/perl/ch-2.pl new file mode 100755 index 0000000000..641eccdb51 --- /dev/null +++ b/challenge-326/jo-37/perl/ch-2.pl @@ -0,0 +1,103 @@ +#!/usr/bin/perl + +use v5.26; +use Test2::V0 qw(!float -no_srand); +use Test2::Tools::Subtest 'subtest_streamed'; +use Getopt::Long; +use experimental 'signatures'; + +use PDL 2.017; + +### Options and Arguments + +my ($tests, $examples, $compress, $verbose); +GetOptions( + 'examples!' => \$examples, + 'tests!' => \$tests, + 'verbose!' => \$verbose, + 'compress!' => \$compress, +) or usage(); + +run_tests($examples, $tests); # tests do not return + +usage() unless @ARGV; + +sub usage { + die <<~EOS; + $0 - (de)compressed list + + usage: $0 [-examples] [-tests] [-compress] [N...] + + -examples + run the examples from the challenge + + -tests + run some tests + + -compress + create a compressed list + + N... + list of integers + + EOS +} + + +### Input and Output + +say $compress ? compressed_list(@ARGV) : decompressed_list(@ARGV); + + +### Implementation +# +# For details see: +# https://github.sommrey.de/the-bears-den/2025/06/18/ch-326.html#task-2 + + +sub decompressed_list { + rld long(@_)->splitdim(0, 2)->xchg(0, 1)->dog; +} + +sub compressed_list { + cat(rle long @_)->xchg(0, 1)->clump(2); +} + + +### Examples and Tests + +sub run_tests ($examples, $tests) { + return unless $examples || $tests; + + state sub run_example ($args, $expected, $name) { + my $result = decompressed_list(@$args)->unpdl; + is $result, $expected, + "$name: (@$args) -> (@$expected)"; + } + + plan 2; + + $examples ? subtest_streamed(examples => sub { + my @examples = ( + [[1, 3, 2, 4], [3, 4, 4], 'example 1'], + [[1, 1, 2, 2], [1, 2, 2], 'example 2'], + [[3, 1, 3, 2], [1, 1, 1, 2, 2, 2], 'example 3'], + ); + plan scalar @examples; + for (@examples) { + run_example @$_; + } + }) : pass 'skip examples'; + + $tests ? subtest_streamed(tests => sub { + plan 3; + is compressed_list(3, 4, 4)->unpdl, [1, 3, 2, 4], + 'compress example 1'; + is compressed_list(1, 2, 2)->unpdl, [1, 1, 2, 2], + 'compress example 2'; + is compressed_list(1, 1, 1, 2, 2, 2)->unpdl, [3, 1, 3, 2], + 'compress example 3'; + }) : pass 'skip tests'; + + exit; +} -- cgit From 6a8d13df76602ecec88e91aec14b9a7d47ed4561 Mon Sep 17 00:00:00 2001 From: Jörg Sommrey <28217714+jo-37@users.noreply.github.com> Date: Wed, 18 Jun 2025 22:45:12 +0200 Subject: Blog for challenge 326 --- challenge-326/jo-37/blog.txt | 1 + 1 file changed, 1 insertion(+) create mode 100644 challenge-326/jo-37/blog.txt diff --git a/challenge-326/jo-37/blog.txt b/challenge-326/jo-37/blog.txt new file mode 100644 index 0000000000..8b4f1a9fee --- /dev/null +++ b/challenge-326/jo-37/blog.txt @@ -0,0 +1 @@ +https://github.sommrey.de/the-bears-den/2025/06/18/ch-326.html -- cgit