From 663e13cd729aab7c658e719e4edf33c110f6a13b Mon Sep 17 00:00:00 2001 From: Jan Krňávek Date: Sat, 28 Aug 2021 00:25:02 +0200 Subject: solutions week 127 --- challenge-127/wambash/raku/ch-1.raku | 20 ++++++++++++++++++++ challenge-127/wambash/raku/ch-2.raku | 20 ++++++++++++++++++++ 2 files changed, 40 insertions(+) create mode 100644 challenge-127/wambash/raku/ch-1.raku create mode 100644 challenge-127/wambash/raku/ch-2.raku diff --git a/challenge-127/wambash/raku/ch-1.raku b/challenge-127/wambash/raku/ch-1.raku new file mode 100644 index 0000000000..a8084942e1 --- /dev/null +++ b/challenge-127/wambash/raku/ch-1.raku @@ -0,0 +1,20 @@ +#!/usr/bin/env raku + +sub disjoint-set (Set() \M, Set() \N) { + M ∩ N ≡ ∅ +} + +multi MAIN () { + lines() + andthen .map: *.words + andthen disjoint-set(|.head(2)) + andthen .say +} + +multi MAIN (Bool :test($)!) { + use Test; + nok disjoint-set( (1,2,5,3,4), (4,6,7,8,9) ); + ok disjoint-set( (1,3,5,7,9), (0,2,4,6,8) ); + done-testing; +} + diff --git a/challenge-127/wambash/raku/ch-2.raku b/challenge-127/wambash/raku/ch-2.raku new file mode 100644 index 0000000000..fd7e771ba6 --- /dev/null +++ b/challenge-127/wambash/raku/ch-2.raku @@ -0,0 +1,20 @@ +#!/usr/bin/env raku + +sub conflict-intervals ( +@intervals ) {; + @intervals.grep: -> $r { @intervals.head($++).first: $r.bounds.any ~~ * } +} + +multi MAIN (*@r) { #= A C B D F H E G + @r + andthen .map: -> $s, $e { $s .. $e }\ + andthen conflict-intervals $_ + andthen .say +} + +multi MAIN (Bool :test($)!) { + use Test; + is-deeply conflict-intervals( 1..4, 3..5, 6..8, 12..13, 3..20), (3..5, 3..20); + is-deeply conflict-intervals( 3..4, 5..7, 6..9, 10..12), (6..9,); + is-deeply conflict-intervals( 3..4, 5..7, 6..9, 10..14, 13..15 ), (6..9, 13..15); + done-testing; +} -- cgit