diff options
| author | Mark A <andemark@a-iot1t.uch.ad.pvt> | 2021-08-30 12:11:00 -0600 |
|---|---|---|
| committer | Mark A <andemark@a-iot1t.uch.ad.pvt> | 2021-08-30 12:11:00 -0600 |
| commit | 37a981a061d0a9899d77accc5ff7ddf93d313a57 (patch) | |
| tree | 62cfe3cd464914e548c7fadabfdf0683dce018a2 | |
| parent | cb8da72f6ed37eec366fb34253839ff119a89c19 (diff) | |
| download | perlweeklychallenge-club-37a981a061d0a9899d77accc5ff7ddf93d313a57.tar.gz perlweeklychallenge-club-37a981a061d0a9899d77accc5ff7ddf93d313a57.tar.bz2 perlweeklychallenge-club-37a981a061d0a9899d77accc5ff7ddf93d313a57.zip | |
initial ch-1.raku
| -rw-r--r-- | challenge-128/mark-anderson/raku/ch-1.raku | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/challenge-128/mark-anderson/raku/ch-1.raku b/challenge-128/mark-anderson/raku/ch-1.raku new file mode 100644 index 0000000000..edc1859f61 --- /dev/null +++ b/challenge-128/mark-anderson/raku/ch-1.raku @@ -0,0 +1,40 @@ +#!/usr/bin/env raku + +say "Example 1"; +.say for max-sub-matrix(<1 0 0 0 1 0>, + <1 1 0 0 0 1>, + <1 0 0 0 0 0>); + +say " "; + +say "Example 2"; +.say for max-sub-matrix(<0 0 1 1>, + <0 0 0 1>, + <0 0 1 0>); + +sub max-sub-matrix(+$matrix) +{ + my %h; + my %results; + + for ^$matrix -> $i + { + for $matrix[$i].join ~~ m:g/00+/ -> $m + { + %h{$i}.push: $m.from..$m.pos-1; + } + } + + for (^$matrix).combinations(2) -> $range + { + for [X] %h{$range.head..$range.tail} -> @rows + { + my $cols = +([(&)] @rows); + my $rows = $range.tail - $range.head + 1; + my $area = $rows * $cols; + %results{"$rows x $cols"} = $area; + } + } + + %results.maxpairs; +} |
