diff options
| author | Mohammad Sajid Anwar <Mohammad.Anwar@yahoo.com> | 2024-02-21 09:05:59 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-02-21 09:05:59 +0000 |
| commit | 7862761478e5406d0709fb61c31e09971a149109 (patch) | |
| tree | 8a6bb5cbcbc55f9dae2e772da5c5acff3779874d | |
| parent | 334ca9a9dad6645373cdd40f225bbe504dbca4f3 (diff) | |
| parent | 9c5499b999d3d42b50db581b6215cf65bc3bdfa8 (diff) | |
| download | perlweeklychallenge-club-7862761478e5406d0709fb61c31e09971a149109.tar.gz perlweeklychallenge-club-7862761478e5406d0709fb61c31e09971a149109.tar.bz2 perlweeklychallenge-club-7862761478e5406d0709fb61c31e09971a149109.zip | |
Merge pull request #9617 from wlmb/challenges
Solve PWC257
| -rw-r--r-- | challenge-257/wlmb/blog.txt | 1 | ||||
| -rwxr-xr-x | challenge-257/wlmb/perl/ch-1.pl | 15 | ||||
| -rwxr-xr-x | challenge-257/wlmb/perl/ch-2.pl | 28 |
3 files changed, 44 insertions, 0 deletions
diff --git a/challenge-257/wlmb/blog.txt b/challenge-257/wlmb/blog.txt new file mode 100644 index 0000000000..f463c9d891 --- /dev/null +++ b/challenge-257/wlmb/blog.txt @@ -0,0 +1 @@ +https://wlmb.github.io/2024/02/20/PWC257/ diff --git a/challenge-257/wlmb/perl/ch-1.pl b/challenge-257/wlmb/perl/ch-1.pl new file mode 100755 index 0000000000..5b78777bb9 --- /dev/null +++ b/challenge-257/wlmb/perl/ch-1.pl @@ -0,0 +1,15 @@ +#!/usr/bin/env perl +# Perl weekly challenge 257 +# Task 1: Smaller than Current +# +# See https://wlmb.github.io/2024/02/20/PWC257/#task-1-smaller-than-current +use v5.36; +use List::Util qw(uniq); +die <<~"FIN" unless @ARGV; + Usage: $0 N1 [N2...] + to count how many numbers Nj are smaller than Ni + FIN +my @sorted=sort {$a<=>$b} uniq @ARGV; +my %count; +$count{$sorted[$_]}=$_ for 0..@sorted-1; +say "@ARGV -> @count{@ARGV}"; diff --git a/challenge-257/wlmb/perl/ch-2.pl b/challenge-257/wlmb/perl/ch-2.pl new file mode 100755 index 0000000000..743c4c5b25 --- /dev/null +++ b/challenge-257/wlmb/perl/ch-2.pl @@ -0,0 +1,28 @@ +#!/usr/bin/env perl +# Perl weekly challenge 257 +# Task 2: Reduced Row Echelon +# +# See https://wlmb.github.io/2024/02/20/PWC257/#task-2-reduced-row-echelon +use v5.36; +use List::AllUtils qw(firstidx reduce all none); +die <<~"FIN" unless @ARGV; + Usage: $0 R0 [R1...] + where Rn is a space separated row of the form + "Mn0 Mn1... Mnm" + and Mij are numbers, the entries of a matrix M, + to test if M is a reduced row echelon matrix + FIN +# Read matrix +my @matrix; +push @matrix, map {[split " "]} @ARGV; +my @indices_first=map {firstidx {$_} @$_} @matrix; #indices of first non null element of each row +my $first_empty=firstidx {$_==-1}@indices_first; # first row of zeroes +$first_empty=@indices_first if $first_empty==-1; # none found +my $result=all{$indices_first[$_]==-1}$first_empty+1..@indices_first-1; # all zero rows at end +$result &&= all{$indices_first[$_] < $indices_first[$_+1]} 0..$first_empty-2; # to right of previous +$result&&=all{$matrix[$_][$indices_first[$_]]==1} 0..$first_empty-1; #leading non zero are ones +for(0..$first_empty-1){ + my $j=$indices_first[$_]; + $result &&= none{$matrix[$_][$j]} (0..$_-1); # check zeroes above first non-zero +} +say join "\n", "[", map({join " ", " [", @$_, "]"}@matrix), "]", "-> ", $result||0, "\n"; |
