From 098d668c1318b7616d4219a2fcdbf20197f9f316 Mon Sep 17 00:00:00 2001 From: Ruben Westerberg Date: Wed, 1 May 2019 19:33:31 +1000 Subject: W6 ch1 and ch2 p5 and p6 solutions added --- challenge-006/ruben-westerberg/perl5/ch-1.pl | 30 ++++++++++++++++++++++++++++ challenge-006/ruben-westerberg/perl6/ch-1.p6 | 11 ++++++++++ 2 files changed, 41 insertions(+) create mode 100755 challenge-006/ruben-westerberg/perl5/ch-1.pl create mode 100755 challenge-006/ruben-westerberg/perl6/ch-1.p6 diff --git a/challenge-006/ruben-westerberg/perl5/ch-1.pl b/challenge-006/ruben-westerberg/perl5/ch-1.pl new file mode 100755 index 0000000000..d8ae69a771 --- /dev/null +++ b/challenge-006/ruben-westerberg/perl5/ch-1.pl @@ -0,0 +1,30 @@ +#!/usr/bin/env perl +# +my $string=join ',', @ARGV; + +my @a=split ',' , $string; +my %bag; +foreach (@a) { + $bag{$_}++; +} +my @k1= sort { $a <=> $b} keys %bag; +my @k2= @k1; push @k2, shift @k2; +my @p; +for (my $i=0; $i<=$#k1; $i++) { + if (abs($k2[$i]-$k1[$i]) > 1 ) { + push @p,$i; + push @p ,$i+1; + } +} +unshift @p, 0; +pop @p; +my @out; +for (my $i=0; $i<$#p; $i+=2) { + my $a=$k1[$p[$i]]; + my $b=$k1[$p[$i+1]]; + my $val= $a-$b == 0? $a: "$a-$b"; + push @out, $val; +} +print (join ",", @out); +print "\n"; + diff --git a/challenge-006/ruben-westerberg/perl6/ch-1.p6 b/challenge-006/ruben-westerberg/perl6/ch-1.p6 new file mode 100755 index 0000000000..9438726911 --- /dev/null +++ b/challenge-006/ruben-westerberg/perl6/ch-1.p6 @@ -0,0 +1,11 @@ +#!/usr/bin/env perl6 +my $string= @*ARGS ?? @*ARGS.join(",")!! prompt "Enter numbers: "; +my $a=$string.split(",",:skip-empty)>>.trim.grep({!/^$/})>>.Int.Bag; +my @r1=$a.keys.sort; +my @diff=@r1.rotate >>-<< @r1; +my @p=(0,|map {|($^k,$k+1) if abs($^v) > 1}, @diff.kv); + +@p.pop; +say join ",", map {@r1[$^a]==@r1[$^b]??@r1[$^a]!!"@r1[$^a]-@r1[$^b]"}, @p; + + -- cgit From d40e69151613169aa47e5ced653ae32a387ae106 Mon Sep 17 00:00:00 2001 From: Ruben Westerberg Date: Mon, 6 May 2019 07:15:29 +1000 Subject: Solutions to w6 ch2 W6Ch2 solutions Also fixed a bug in 4W --- challenge-006/ruben-westerberg/perl5/ch-2.pl | 5 +++++ challenge-006/ruben-westerberg/perl6/ch-2.p6 | 27 +++++++++++++++++++++++++++ 2 files changed, 32 insertions(+) create mode 100755 challenge-006/ruben-westerberg/perl5/ch-2.pl create mode 100755 challenge-006/ruben-westerberg/perl6/ch-2.p6 diff --git a/challenge-006/ruben-westerberg/perl5/ch-2.pl b/challenge-006/ruben-westerberg/perl5/ch-2.pl new file mode 100755 index 0000000000..73928169ae --- /dev/null +++ b/challenge-006/ruben-westerberg/perl5/ch-2.pl @@ -0,0 +1,5 @@ +#!/usr/bin/env perl +use strict; +use warnings; +use bigrat qw; +print bexp(bpi(50)*sqrt(163),50); diff --git a/challenge-006/ruben-westerberg/perl6/ch-2.p6 b/challenge-006/ruben-westerberg/perl6/ch-2.p6 new file mode 100755 index 0000000000..a82f43c516 --- /dev/null +++ b/challenge-006/ruben-westerberg/perl6/ch-2.p6 @@ -0,0 +1,27 @@ +#!/usr/bin/env perl6 + +my $bigPi=FatRat.new(31415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679,10**100); + +sub factorial($n) { + constant @f= (1.FatRat, |[\*] 1.FatRat..*); + @f[$n]; +} +sub taylor-e ($atVal) { + + my $sum=0.FatRat; + my $x=$atVal.FatRat; + for 0..200 { + $sum+=($x**$_)/factorial($_); + say "Iteration $_: " ~ $sum.Str.substr(0,50); + } + $sum; +} + +sub newton-sqrt($val, $target, $repeat){ + my $guess=$val.FatRat; + for ^$repeat { + $guess:=($guess - ($guess**2 -$target)/(2*$guess)); + } + $guess; +} +say taylor-e($bigPi*newton-sqrt(10,163,6)).Str.substr(0,50); -- cgit