diff options
| author | Mohammad S Anwar <Mohammad.Anwar@yahoo.com> | 2023-04-03 00:03:00 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-04-03 00:03:00 +0100 |
| commit | 6c0d7b957b00d5d239cfcca00946c4f2dbfb998b (patch) | |
| tree | 4544e9dd2b7a0980d59f105410a6e9e333314c1e | |
| parent | b4f742f50f988d82c10596f83795875e99c7fd66 (diff) | |
| parent | 3c83d2fb8db2427385006d01fa90f6d732ebf980 (diff) | |
| download | perlweeklychallenge-club-6c0d7b957b00d5d239cfcca00946c4f2dbfb998b.tar.gz perlweeklychallenge-club-6c0d7b957b00d5d239cfcca00946c4f2dbfb998b.tar.bz2 perlweeklychallenge-club-6c0d7b957b00d5d239cfcca00946c4f2dbfb998b.zip | |
Merge pull request #7812 from zapwai/branch-for-210
Week 210
| -rw-r--r-- | challenge-210/zapwai/perl/ch-1.pl | 20 | ||||
| -rw-r--r-- | challenge-210/zapwai/perl/ch-2.pl | 25 |
2 files changed, 45 insertions, 0 deletions
diff --git a/challenge-210/zapwai/perl/ch-1.pl b/challenge-210/zapwai/perl/ch-1.pl new file mode 100644 index 0000000000..1f03462196 --- /dev/null +++ b/challenge-210/zapwai/perl/ch-1.pl @@ -0,0 +1,20 @@ +use v5.30.0; +my @int = (2, 3, 1); +#my @int = (1,1,2,2, 3, 2); +say "Input: \@int = (".join(", ",@int).")"; +my %freq; +$freq{$_}++ for (@int); +my $max; +my $val; +foreach my $key (keys %freq) { + my $sum = 0; + for (-1 .. 1) { + my $n = $key + $_; + $sum += $n*$freq{$n}; + } + if ($max < $sum) { + $val = $key; + $max = $sum; + } +} +say "Output: $max (by removing $val)"; diff --git a/challenge-210/zapwai/perl/ch-2.pl b/challenge-210/zapwai/perl/ch-2.pl new file mode 100644 index 0000000000..f43a9e9234 --- /dev/null +++ b/challenge-210/zapwai/perl/ch-2.pl @@ -0,0 +1,25 @@ +use v5.30.0; +my @list = (2,3,-1); +say "Input: \@list = (".join(", ",@list).")"; +for (1 .. @list) { + my $positive_value_preceding = 0; + last if ($#list == 0); + foreach my $i (0 .. $#list) { + if ($list[$i] < 0) { + if ($positive_value_preceding) { + my $bad_entry = $i; + $bad_entry-- if ( abs($list[$i - 1]) <= abs($list[$i]) ); + if (abs($list[$i - 1]) == abs($list[$i])) { + splice @list, $i, 1; + $i--; + } + splice @list, $bad_entry, 1; + $positive_value_preceding = 0; + redo; + } + } else { + $positive_value_preceding = 1; + } + } +} +say "Output: (".join(", ",@list).")"; |
