diff options
| author | Mark <53903062+andemark@users.noreply.github.com> | 2022-02-14 16:19:34 +0000 |
|---|---|---|
| committer | Mark <53903062+andemark@users.noreply.github.com> | 2022-02-14 16:19:34 +0000 |
| commit | 9cd8ddc288cd207c1c719ade20843bcb9833b1d4 (patch) | |
| tree | fc788ab59c0acf585514e4193a8727276baaa2e9 /challenge-152/mark-anderson | |
| parent | ff372a96c896751bacce3f2521ba5d880041ff42 (diff) | |
| download | perlweeklychallenge-club-9cd8ddc288cd207c1c719ade20843bcb9833b1d4.tar.gz perlweeklychallenge-club-9cd8ddc288cd207c1c719ade20843bcb9833b1d4.tar.bz2 perlweeklychallenge-club-9cd8ddc288cd207c1c719ade20843bcb9833b1d4.zip | |
Challenge 152 Solutions (Raku)
Diffstat (limited to 'challenge-152/mark-anderson')
| -rw-r--r-- | challenge-152/mark-anderson/raku/ch-2.raku | 32 |
1 files changed, 16 insertions, 16 deletions
diff --git a/challenge-152/mark-anderson/raku/ch-2.raku b/challenge-152/mark-anderson/raku/ch-2.raku index 25144dbcc2..10e30451d0 100644 --- a/challenge-152/mark-anderson/raku/ch-2.raku +++ b/challenge-152/mark-anderson/raku/ch-2.raku @@ -2,24 +2,24 @@ use Test; -is rectangle-area((-1,0), (2,2), (0,-1), (4,4)), 22; -is rectangle-area((-3,-1), (1,3), (-1,-3), (2,2)), 25; -is rectangle-area((1,1), (2,2), (3,3), (4,4)), 2; +is rectangle-area((-1,0), (2,2), (0,-1), (4,4)), 22; +is rectangle-area((-3,-1), (1,3), (-1,-3), (2,2)), 25; +is rectangle-area((1,1), (2,2), (3,3), (4,4)), 2; +is rectangle-area((-1,-1), (-2,-2), (1,1), (2,2)), 2; +is rectangle-area((1,1), (2,2), (-1,-1), (-2,-2)), 2; +is rectangle-area((3,3), (4,4), (1,1), (2,2)), 2; +is rectangle-area((4,2), (7,5), (2,3), (5,7)), 19; -sub rectangle-area($bl_1, $tr_1, $bl_2, $tr_2) +sub rectangle-area(+@p) { - my $area_1 = abs($bl_1[0] - $tr_1[0]) * abs($bl_1[1] - $tr_1[1]); - my $area_2 = abs($bl_2[0] - $tr_2[0]) * abs($bl_2[1] - $tr_2[1]); - - my $int_bl_x = max($bl_1[0], $bl_2[0]); - my $int_tr_x = min($tr_1[0], $tr_2[0]); - my $int_bl_y = max($bl_1[1], $bl_2[1]); - my $int_tr_y = min($tr_1[1], $tr_2[1]); + my $p = @p.map(|*); + + my $int = flat (($p[0,4], $p[1,5])>>.max, ($p[2,6], $p[3,7])>>.min); - my $int_x_dist = $int_tr_x - $int_bl_x; - my $int_y_dist = $int_tr_y - $int_bl_y; + my $int-x-dist = [-] $int[2,0]; + my $int-y-dist = [-] $int[3,1]; + + my $int-area = $int-x-dist|$int-y-dist < 0 ?? 0 !! $int-x-dist * $int-y-dist; - my $area_int = $int_x_dist|$int_y_dist < 0 ?? 0 !! $int_x_dist*$int_y_dist; - - return $area_1 + $area_2 - $area_int; + abs(([-] $p[0,2]) * ([-] $p[1,3])) + abs(([-] $p[4,6]) * ([-] $p[5,7])) - $int-area; } |
