aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuca Ferrari <fluca1978@gmail.com>2021-06-07 10:23:39 +0200
committerLuca Ferrari <fluca1978@gmail.com>2021-06-07 18:18:01 +0200
commit72f21487ddd96df67f03ae18c16a167a722bbaa5 (patch)
tree8ed00b3a849836472a1ac9ab4c3306216f92f9ee
parent8024a172efcd9ea08cd827c680427f7183771c2d (diff)
downloadperlweeklychallenge-club-72f21487ddd96df67f03ae18c16a167a722bbaa5.tar.gz
perlweeklychallenge-club-72f21487ddd96df67f03ae18c16a167a722bbaa5.tar.bz2
perlweeklychallenge-club-72f21487ddd96df67f03ae18c16a167a722bbaa5.zip
Task 1 almost done
-rw-r--r--challenge-116/luca-ferrari/raku/ch-1.p641
1 files changed, 41 insertions, 0 deletions
diff --git a/challenge-116/luca-ferrari/raku/ch-1.p6 b/challenge-116/luca-ferrari/raku/ch-1.p6
new file mode 100644
index 0000000000..e1c71ba561
--- /dev/null
+++ b/challenge-116/luca-ferrari/raku/ch-1.p6
@@ -0,0 +1,41 @@
+#!raku
+
+sub MAIN( Int $N where { $N >= 10 } ) {
+ my @digits = $N.split( '', :skip-empty );
+ my $min-length = 1;
+
+ my @numbers;
+
+ my $i = 0;
+ my $done = True;
+ while $done && $i < @digits.elems {
+
+
+
+ # first number ever
+ @numbers.push: @digits[ $i ] if ! @numbers;
+ my $current-number = @numbers[ * - 1 ];
+
+ # compute available next numbers
+ my @next-number = $current-number + 1, $current-number - 1;
+
+ # see if there is room for any of the next
+ # numbers in the remaining array of digits
+ $done = False;
+ for @next-number {
+ my $length = $_.Str.chars;
+ if $i + $length < @digits.elems {
+ my $current = @digits[ $i + 1 .. $i + $length ].join.Int;
+ if $current == $_ {
+ @numbers.push: $current;
+ $i += $length;
+ $done = True;
+ last;
+ }
+ }
+ }
+ }
+
+ # all done
+ say @numbers if $done;
+}