From 0940ee57dbd2d4a9918a74e52e3cc1266eb5196f Mon Sep 17 00:00:00 2001 From: Niels van Dijke Date: Thu, 13 Aug 2020 10:30:58 +0000 Subject: - Fixed regexp for command-line argument test - Added second half of 'peak neighbor' test --- challenge-071/perlboy1967/perl/ch-1.pl | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/challenge-071/perlboy1967/perl/ch-1.pl b/challenge-071/perlboy1967/perl/ch-1.pl index eb84290645..c4fb104fd0 100755 --- a/challenge-071/perlboy1967/perl/ch-1.pl +++ b/challenge-071/perlboy1967/perl/ch-1.pl @@ -12,7 +12,7 @@ use warnings; my ($N) = @ARGV; die "Argument must be a positive number ( 1 <= N <= 50)" - unless (defined $N && $N =~ m#^[2-9][0-9]*# and $N <= 50); + unless (defined $N && $N =~ m#^[1-9][0-9]*$# and $N <= 50); my @iPool = (1 .. 50); my @array = map { splice(@iPool, int(rand(scalar(@iPool))), 1) } (1 .. $N); @@ -20,7 +20,8 @@ my @array = map { splice(@iPool, int(rand(scalar(@iPool))), 1) } (1 .. $N); my @peak = map { $array[$_] } grep { $array[$_] - if ($array[$_] > ($array[$_ + 1] // 0)); + if ($array[$_] > ($array[$_ + 1] // 0) and + $array[$_] > ($array[$_ - 1] // 0)); } (0 .. $N - 2); printf "Array: [%s]\n", join(', ', @array); -- cgit From ce03143ce07f1619f05221a4e3760a28cf19a917 Mon Sep 17 00:00:00 2001 From: Niels van Dijke Date: Thu, 13 Aug 2020 10:35:00 +0000 Subject: Task 1 & 2 --- challenge-073/perlboy1967/perl/ch-1.pl | 35 ++++++++++++++++++++++++++++++++++ challenge-073/perlboy1967/perl/ch-2.pl | 32 +++++++++++++++++++++++++++++++ 2 files changed, 67 insertions(+) create mode 100755 challenge-073/perlboy1967/perl/ch-1.pl create mode 100755 challenge-073/perlboy1967/perl/ch-2.pl diff --git a/challenge-073/perlboy1967/perl/ch-1.pl b/challenge-073/perlboy1967/perl/ch-1.pl new file mode 100755 index 0000000000..abe3d9e81e --- /dev/null +++ b/challenge-073/perlboy1967/perl/ch-1.pl @@ -0,0 +1,35 @@ +#!/usr/bin/perl + +# Perl Weekly Challenge - 073 +# - https://perlweeklychallenge.org/blog/perl-weekly-challenge-073/ +# +# Task 1 - Min Sliding Window +# +# Author: Niels 'PerlBoy' van Dijke + +use strict; +use warnings; + +use List::Util qw(min); + +my ($S) = @ARGV; + +die "S must be a positive integer" + unless (defined $S and $S =~ m#^[1-9][0-9]*$#); + +my @S; + +# Create list with random integer values +my @A = map {int(rand(100))} (1 .. $S * 3); + +printf "Input:\n\t\@A = (%s)\n\t\$S = %d\n\n", join(', ', @A), $S; + +for (my $i = 0; $i < scalar(@A) - $S + 1; $i++) { + my @s = @A[$i .. $i + $S - 1]; + + push(@S, min(@s)); + + printf "min(%s) = %d\n", join(', ',@s), $S[-1]; +} + +printf "\nOutput:\n\t\@S = (%s)\n", join(', ', @S); diff --git a/challenge-073/perlboy1967/perl/ch-2.pl b/challenge-073/perlboy1967/perl/ch-2.pl new file mode 100755 index 0000000000..55ecb89b0f --- /dev/null +++ b/challenge-073/perlboy1967/perl/ch-2.pl @@ -0,0 +1,32 @@ +#!/usr/bin/perl + +# Perl Weekly Challenge - 073 +# - https://perlweeklychallenge.org/blog/perl-weekly-challenge-073/ +# +# Task 2 - Smallest Neighbour +# +# Author: Niels 'PerlBoy' van Dijke + +use strict; +use warnings; + +use List::Util qw(min); + +my @N = (0); + +# Create list with random integer values +my @A = map {int(rand(100))} (1 .. 10); + +printf "Input:\n\t\@A = (%s)\n\n", join(', ', @A); + +for (my $i = 1; $i < scalar(@A); $i++) { + my @s = @A[0 .. $i-1]; + my $min = min(@s); + + push(@N, $min < $A[$i] ? $min : 0); + + printf "%d\tmin(%s) = %d, %d < %d ? %d : 0 => %d\n", + $A[$i], join(', ',@s), $min, $A[$i], $min, $min, $N[-1]; +} + +printf "\nOutput:\n\t\@S = (%s)\n", join(', ', @N); -- cgit