aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMohammad S Anwar <Mohammad.Anwar@yahoo.com>2021-12-01 18:00:58 +0000
committerGitHub <noreply@github.com>2021-12-01 18:00:58 +0000
commit03041b51a5fbc3de8f65da7d015df4bc39f5a9f3 (patch)
tree9b6b4b27558e441f5ea3dd2e58d2fc0e1b768a7a
parent0644e5d306c92b29e60cefa9410c307f9418d69c (diff)
parent29cd549b7300651b3eee9da4c8a43ecde8595a07 (diff)
downloadperlweeklychallenge-club-03041b51a5fbc3de8f65da7d015df4bc39f5a9f3.tar.gz
perlweeklychallenge-club-03041b51a5fbc3de8f65da7d015df4bc39f5a9f3.tar.bz2
perlweeklychallenge-club-03041b51a5fbc3de8f65da7d015df4bc39f5a9f3.zip
Merge pull request #5303 from akarelas/pr-alex
alexander karelas's solution to challenge 141 #2
-rwxr-xr-xchallenge-141/alexander-karelas/ch-2.pl29
1 files changed, 29 insertions, 0 deletions
diff --git a/challenge-141/alexander-karelas/ch-2.pl b/challenge-141/alexander-karelas/ch-2.pl
new file mode 100755
index 0000000000..37bd52afe9
--- /dev/null
+++ b/challenge-141/alexander-karelas/ch-2.pl
@@ -0,0 +1,29 @@
+#!/usr/bin/env perl
+
+use v5.32;
+use warnings;
+
+use List::Util 'any';
+
+use experimental 'signatures';
+
+sub find_like ($m, $n) {
+ my @digits = split //, $m;
+ my $length = @digits;
+ my @return;
+
+ for (my $i = 1; $i <= 2 ** $length - 2; $i++) {
+ my @onoff = split //, sprintf("%0${length}b", $i);
+ my $idx = 0;
+ my $candidate = join '', map {
+ my $digit = $digits[$_];
+ my $onoff = $onoff[$_];
+ $onoff ? ($digit) : ();
+ } (0 .. $length-1);
+ push @return, $candidate if $candidate % $n == 0;
+ }
+
+ return sort {$a <=> $b} @return;
+}
+
+say foreach find_like(@ARGV);