diff options
| author | Mohammad Sajid Anwar <Mohammad.Anwar@yahoo.com> | 2023-12-06 11:14:23 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-12-06 11:14:23 +0000 |
| commit | 0221786b35988f6001981bed848deeed7785213a (patch) | |
| tree | 8fd783da8c7c641cf4aeb2e2c786ef0b1f98e7bc /challenge-246 | |
| parent | 40df386111c052c9c5a9f2117b3ce7b519a690bc (diff) | |
| parent | 09652b11af0fbbc7fd3782311f52d823a0f8a743 (diff) | |
| download | perlweeklychallenge-club-0221786b35988f6001981bed848deeed7785213a.tar.gz perlweeklychallenge-club-0221786b35988f6001981bed848deeed7785213a.tar.bz2 perlweeklychallenge-club-0221786b35988f6001981bed848deeed7785213a.zip | |
Merge pull request #9207 from andemark/challenge-246
ch-2.raku touch-up
Diffstat (limited to 'challenge-246')
| -rw-r--r-- | challenge-246/mark-anderson/raku/ch-2.raku | 26 |
1 files changed, 6 insertions, 20 deletions
diff --git a/challenge-246/mark-anderson/raku/ch-2.raku b/challenge-246/mark-anderson/raku/ch-2.raku index b411ffd00a..52ef177f92 100644 --- a/challenge-246/mark-anderson/raku/ch-2.raku +++ b/challenge-246/mark-anderson/raku/ch-2.raku @@ -7,27 +7,13 @@ ok linear-recurrence-of-second-order([4,1,2,-3,8]); sub linear-recurrence-of-second-order(@a) { - my @eqn = @a.rotor(3 => -2).head(2); - my $p = p(@eqn).narrow; - my $q = q(@eqn.pop, $p).narrow; + my @eqn = @a.rotor(3 => -2); - return False unless all($p, $q) ~~ Int; + my $p = (.[2] / .[0] given .[0] >>*>> .[1;1] >>-<< .[1] >>*>> .[0;1]).narrow given @eqn; - @a eqv (@a[0], @a[1], -> $a, $b { $a*$p + $b*$q }...*).head(5).Array -} - -sub p(@a) -{ - given @a - { - .[2] / .[0] given .[0] >>*>> .[1;1] >>-<< .[1] >>*>> .[0;1] - } -} + my $q = ((.[2] - .[0]*$p) / .[1]).narrow given @eqn.tail; -sub q(@a, $p) -{ - given @a - { - (.[2] - .[0]*$p) / .[1] - } + return False unless all($p, $q) ~~ Int; + + @a eqv (@a[0], @a[1], { $^a*$p + $^b*$q }...*).head(5).Array } |
