aboutsummaryrefslogtreecommitdiff
path: root/challenge-201
diff options
context:
space:
mode:
Diffstat (limited to 'challenge-201')
-rw-r--r--challenge-201/carlos-oliveira/raku/ch-1.raku9
-rw-r--r--challenge-201/carlos-oliveira/raku/ch-2.raku17
2 files changed, 26 insertions, 0 deletions
diff --git a/challenge-201/carlos-oliveira/raku/ch-1.raku b/challenge-201/carlos-oliveira/raku/ch-1.raku
new file mode 100644
index 0000000000..6986edd5f8
--- /dev/null
+++ b/challenge-201/carlos-oliveira/raku/ch-1.raku
@@ -0,0 +1,9 @@
+use Test;
+
+sub missing-numbers (Int:D @numbers --> Set:D[Int:D]) {
+ return ((0..@numbers) (-) @numbers);
+}
+
+is-deeply missing-numbers(my Int @ = 0,1,3), Set.new(2);
+is-deeply missing-numbers(my Int @ = 0,1), Set.new(2);
+is-deeply missing-numbers(my Int @ = 0,5,5,4,5), Set.new(1,2,3);
diff --git a/challenge-201/carlos-oliveira/raku/ch-2.raku b/challenge-201/carlos-oliveira/raku/ch-2.raku
new file mode 100644
index 0000000000..34946c4eeb
--- /dev/null
+++ b/challenge-201/carlos-oliveira/raku/ch-2.raku
@@ -0,0 +1,17 @@
+sub pile-pennies (UInt:D $n) {
+ # repeat elements to treat the problem as a combination with repetition
+ my @elements-with-repetition = (1..$n).map({ $_ xx $n }).flat;
+
+ for @elements-with-repetition
+ .combinations(1..$n)
+ .grep(*.sum == $n)
+ .unique(:with(&infix:<eqv>))
+ .reverse -> @row
+ {
+ say @row.join: ' ';
+ }
+}
+
+pile-pennies 5;
+print "\n";
+pile-pennies 6;