diff options
| author | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2019-08-22 13:02:33 +0100 |
|---|---|---|
| committer | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2019-08-22 13:02:33 +0100 |
| commit | 5fc80ca35a61b7e84529f422ba4101ed3aae9e70 (patch) | |
| tree | 96b0c52b9f72e3724ed2502ea311519470a4fea6 | |
| parent | adbf2dc24520a42cb4f4c77acb307fda2c77decd (diff) | |
| download | perlweeklychallenge-club-5fc80ca35a61b7e84529f422ba4101ed3aae9e70.tar.gz perlweeklychallenge-club-5fc80ca35a61b7e84529f422ba4101ed3aae9e70.tar.bz2 perlweeklychallenge-club-5fc80ca35a61b7e84529f422ba4101ed3aae9e70.zip | |
- Added solutions by Laurent Rosenfeld.
| -rw-r--r-- | challenge-022/laurent-rosenfeld/blog.txt | 1 | ||||
| -rw-r--r-- | challenge-022/laurent-rosenfeld/perl5/ch-1.pl | 22 | ||||
| -rw-r--r-- | challenge-022/laurent-rosenfeld/perl5/ch-2.pl | 50 | ||||
| -rw-r--r-- | challenge-022/laurent-rosenfeld/perl6/ch-1.p6 | 4 | ||||
| -rw-r--r-- | challenge-022/laurent-rosenfeld/perl6/ch-2.p6 | 50 | ||||
| -rw-r--r-- | stats/pwc-current.json | 113 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown-summary.json | 86 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown.json | 372 | ||||
| -rw-r--r-- | stats/pwc-leaders.json | 908 | ||||
| -rw-r--r-- | stats/pwc-summary-1-30.json | 102 | ||||
| -rw-r--r-- | stats/pwc-summary-31-60.json | 104 | ||||
| -rw-r--r-- | stats/pwc-summary-61-90.json | 108 | ||||
| -rw-r--r-- | stats/pwc-summary-91-120.json | 60 | ||||
| -rw-r--r-- | stats/pwc-summary.json | 50 |
14 files changed, 1090 insertions, 940 deletions
diff --git a/challenge-022/laurent-rosenfeld/blog.txt b/challenge-022/laurent-rosenfeld/blog.txt new file mode 100644 index 0000000000..b3e03920de --- /dev/null +++ b/challenge-022/laurent-rosenfeld/blog.txt @@ -0,0 +1 @@ +http://blogs.perl.org/users/laurent_r/2019/08/perl-weekly-challenge-22-sexy-prime-pairs-and-compression-algorithm.html diff --git a/challenge-022/laurent-rosenfeld/perl5/ch-1.pl b/challenge-022/laurent-rosenfeld/perl5/ch-1.pl new file mode 100644 index 0000000000..0a9ff01b94 --- /dev/null +++ b/challenge-022/laurent-rosenfeld/perl5/ch-1.pl @@ -0,0 +1,22 @@ +#!/usr/bin/perl +use strict; +use warnings; +use feature qw/say/; + +sub is_prime{ + my $num = shift; + for my $i (2 .. $num ** .5) { + return 0 if $num % $i == 0; + } + return 1; +} + +my ($candidate, $count) = (2, 0); +while (1) { + if (is_prime $candidate and is_prime $candidate + 6) { + say "$candidate ", $candidate + 6; + $count ++ + } + last if $count >= 10; + $candidate ++; +} diff --git a/challenge-022/laurent-rosenfeld/perl5/ch-2.pl b/challenge-022/laurent-rosenfeld/perl5/ch-2.pl new file mode 100644 index 0000000000..e1a44dc7e6 --- /dev/null +++ b/challenge-022/laurent-rosenfeld/perl5/ch-2.pl @@ -0,0 +1,50 @@ +#!/usr/bin/perl +use strict; +use warnings; +use feature qw /say/; +use constant start_dict_size => 256; +use utf8; + +sub encode { + my $in = shift; + my %dict = map { chr $_ => $_ } 0 .. start_dict_size - 1; + my $ω = ""; + my @result; + + for my $c (split //, $in) { + my $ωc = $ω . $c; + if (exists $dict{$ωc}) { + $ω = $ωc; + } else { + push @result, $dict{$ω}; + $dict{$ωc} = scalar keys %dict; + $ω = $c; + } + } + push @result, $dict{$ω} if length $ω; + return @result; +} +sub decode { + my @encoded = @_; + my $dict_size = start_dict_size; + my %dict = map { $_ => chr } 0 .. start_dict_size - 1;; + my $ω = $dict{shift @encoded}; + my @result = ($ω); + for my $i (@encoded) { + my $str; + if (exists $dict{$i}) { + $str = $dict{$i}; + } elsif ($i == $dict_size) { + $str = $ω . substr $ω, 0, 1; + } else { die "Error on $i" } + push @result, $str; + $dict{$dict_size++} = $ω . substr $str, 0, 1; + $ω = $str; + } + return join "", @result; +} + +my $input_str = 'TOBEORNOTTOBETOBEORNOTTOBETOBEORNOTTOBE'; +my @encoded = encode $input_str; +say "@encoded"; +say decode(@encoded); diff --git a/challenge-022/laurent-rosenfeld/perl6/ch-1.p6 b/challenge-022/laurent-rosenfeld/perl6/ch-1.p6 new file mode 100644 index 0000000000..a5271748af --- /dev/null +++ b/challenge-022/laurent-rosenfeld/perl6/ch-1.p6 @@ -0,0 +1,4 @@ +use v6; + +my @sexy-primes = grep { .is-prime and ($_ + 6).is-prime}, (2, 3, *+2 ... Inf); +say "@sexy-primes[$_] ", @sexy-primes[$_] + 6 for ^10; diff --git a/challenge-022/laurent-rosenfeld/perl6/ch-2.p6 b/challenge-022/laurent-rosenfeld/perl6/ch-2.p6 new file mode 100644 index 0000000000..32529819d7 --- /dev/null +++ b/challenge-022/laurent-rosenfeld/perl6/ch-2.p6 @@ -0,0 +1,50 @@ +use v6; + +constant $start-dict-size = 26; + +sub encode (Str $in) { + my %dict = map { $_[0] => $_[1] }, + ( ('A'..'Z') Z (^$start-dict-size) ); + my $ω = ""; + my @result = gather { + for $in.comb -> $c { + my $ωc = $ω ~ $c; + if %dict{$ωc}:exists { + $ω = $ωc; + } else { + take %dict{$ω}; + %dict{$ωc} = +%dict; + $ω = $c; + } + } + take %dict{$ω} if $ω.chars; + } + # say %dict; + return @result; +} +sub decode (@encoded) { + my $dict-size = $start-dict-size; + my %dict = map { $_[1] => $_[0] }, + ( ('A'..'Z') Z (^$start-dict-size) ); + my $ω = %dict{shift @encoded}; + my @result = gather { + take $ω; + for @encoded -> $i { + my $str; + if %dict{$i}:exists { + $str = %dict{$i}; + } elsif $i == $dict-size { + $str = $ω ~ $ω.substr(0,1) + } + take $str; + %dict{$dict-size++} = $ω ~ $str.substr(0,1); + $ω = $str; + } + } + return join "", @result; +} + +my $input_str = 'TOBEORNOTTOBETOBEORNOTTOBETOBEORNOTTOBE'; +my @encoded = encode $input_str; +say @encoded; +say decode @encoded; diff --git a/stats/pwc-current.json b/stats/pwc-current.json index 36aeb50fc5..469638b895 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,53 +1,41 @@ { - "series" : [ - { - "name" : "Perl Weekly Challenge - 022", - "colorByPoint" : 1, - "data" : [ - { - "y" : 1, - "name" : "Duane Powell", - "drilldown" : "Duane Powell" - }, - { - "name" : "Simon Proctor", - "drilldown" : "Simon Proctor", - "y" : 2 - }, - { - "y" : 1, - "name" : "Steven Wilson", - "drilldown" : "Steven Wilson" - }, - { - "name" : "Yet Ebreo", - "drilldown" : "Yet Ebreo", - "y" : 4 - } - ] - } - ], "yAxis" : { "title" : { "text" : "Total Solutions" } }, - "tooltip" : { - "followPointer" : 1, - "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>", - "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>" + "xAxis" : { + "type" : "category" }, "drilldown" : { "series" : [ { + "name" : "Duane Powell", + "data" : [ + [ + "Perl 5", + 1 + ] + ], + "id" : "Duane Powell" + }, + { + "name" : "Laurent Rosenfeld", "data" : [ [ "Perl 5", + 2 + ], + [ + "Perl 6", + 2 + ], + [ + "Blog", 1 ] ], - "id" : "Duane Powell", - "name" : "Duane Powell" + "id" : "Laurent Rosenfeld" }, { "id" : "Simon Proctor", @@ -70,8 +58,6 @@ "id" : "Steven Wilson" }, { - "name" : "Yet Ebreo", - "id" : "Yet Ebreo", "data" : [ [ "Perl 5", @@ -81,19 +67,48 @@ "Perl 6", 2 ] - ] + ], + "id" : "Yet Ebreo", + "name" : "Yet Ebreo" } ] }, + "series" : [ + { + "data" : [ + { + "drilldown" : "Duane Powell", + "y" : 1, + "name" : "Duane Powell" + }, + { + "name" : "Laurent Rosenfeld", + "drilldown" : "Laurent Rosenfeld", + "y" : 5 + }, + { + "name" : "Simon Proctor", + "y" : 2, + "drilldown" : "Simon Proctor" + }, + { + "name" : "Steven Wilson", + "drilldown" : "Steven Wilson", + "y" : 1 + }, + { + "name" : "Yet Ebreo", + "drilldown" : "Yet Ebreo", + "y" : 4 + } + ], + "colorByPoint" : 1, + "name" : "Perl Weekly Challenge - 022" + } + ], "title" : { "text" : "Perl Weekly Challenge - 022" }, - "chart" : { - "type" : "column" - }, - "subtitle" : { - "text" : "[Champions: 4] Last updated at 2019-08-22 11:53:42 GMT" - }, "plotOptions" : { "series" : { "dataLabels" : { @@ -106,7 +121,15 @@ "legend" : { "enabled" : 0 }, - "xAxis" : { - "type" : "category" + "tooltip" : { + "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>", + "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>", + "followPointer" : 1 + }, + "subtitle" : { + "text" : "[Champions: 5] Last updated at 2019-08-22 12:02:04 GMT" + }, + "chart" : { + "type" : "column" } } diff --git a/stats/pwc-language-breakdown-summary.json b/stats/pwc-language-breakdown-summary.json index 6661f742dc..77a2f7d9c0 100644 --- a/stats/pwc-language-breakdown-summary.json +++ b/stats/pwc-language-breakdown-summary.json @@ -1,63 +1,63 @@ { - "yAxis" : { - "min" : 0, - "title" : { - "text" : null - } - }, - "tooltip" : { - "pointFormat" : "<b>{point.y:.0f}</b>" - }, - "subtitle" : { - "text" : "Last updated at 2019-08-22 11:53:48 GMT" - }, - "xAxis" : { - "type" : "category", - "labels" : { - "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" - } - } - }, - "legend" : { - "enabled" : "false" - }, - "title" : { - "text" : "Perl Weekly Challenge Contributions - 2019" - }, "series" : [ { "name" : "Contributions", + "dataLabels" : { + "format" : "{point.y:.0f}", + "style" : { + "fontSize" : "13px", + "fontFamily" : "Verdana, sans-serif" + }, + "color" : "#FFFFFF", + "align" : "right", + "y" : 10, + "rotation" : -90, + "enabled" : "true" + }, "data" : [ [ "Blog", - 216 + 217 ], [ "Perl 5", - 887 + 889 ], [ "Perl 6", - 530 + 532 ] - ], - "dataLabels" : { - "align" : "right", - "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" - }, - "format" : "{point.y:.0f}", - "color" : "#FFFFFF", - "rotation" : -90, - "enabled" : "true", - "y" : 10 - } + ] } ], + "legend" : { + "enabled" : "false" + }, + "yAxis" : { + "min" : 0, + "title" : { + "text" : null + } + }, "chart" : { "type" : "column" + }, + "xAxis" : { + "labels" : { + "style" : { + "fontFamily" : "Verdana, sans-serif", + "fontSize" : "13px" + } + }, + "type" : "category" + }, + "title" : { + "text" : "Perl Weekly Challenge Contributions - 2019" + }, + "tooltip" : { + "pointFormat" : "<b>{point.y:.0f}</b>" + }, + "subtitle" : { + "text" : "Last updated at 2019-08-22 12:02:23 GMT" } } diff --git a/stats/pwc-language-breakdown.json b/stats/pwc-language-breakdown.json index c06d4a1d2a..6575dc4d74 100644 --- a/stats/pwc-language-breakdown.json +++ b/stats/pwc-language-breakdown.json @@ -1,36 +1,132 @@ { - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } - }, - "plotOptions" : { - "series" : { - "borderWidth" : 0, - "dataLabels" : { - "format" : "{point.y}", - "enabled" : 1 - } - } - }, - "tooltip" : { - "headerFormat" : "<span style=\"font-size:11px\"></span>", - "pointFormat" : "<span style=\"color:{point.color}\">Challenge {point.name}</span>: <b>{point.y:f}</b><br/>", - "followPointer" : "true" - }, - "subtitle" : { - "text" : "Click the columns to drilldown the language breakdown. Last updated at 2019-08-22 11:53:48 GMT" - }, - "xAxis" : { - "type" : "category" - }, "legend" : { "enabled" : "false" }, + "series" : [ + { + "name" : "Perl Weekly Challenge Languages", + "data" : [ + { + "y" : 123, + "name" : "#001", + "drilldown" : "001" + }, + { + "y" : 104, + "name" : "#002", + "drilldown" : "002" + }, + { + "drilldown" : "003", + "name" : "#003", + "y" : 66 + }, + { + "drilldown" : "004", + "y" : 84, + "name" : "#004" + }, + { + "drilldown" : "005", + "y" : 66, + "name" : "#005" + }, + { + "y" : 47, + "name" : "#006", + "drilldown" : "006" + }, + { + "y" : 55, + "name" : "#007", + "drilldown" : "007" + }, + { + "drilldown" : "008", + "y" : 68, + "name" : "#008" + }, + { + "y" : 66, + "name" : "#009", + "drilldown" : "009" + }, + { + "y" : 59, + "name" : "#010", + "drilldown" : "010" + }, + { + "name" : "#011", + "y" : 78, + "drilldown" : "011" + }, + { + "drilldown" : "012", + "name" : "#012", + "y" : 82 + }, + { + "y" : 75, + "name" : "#013", + "drilldown" : "013" + }, + { + "drilldown" : "014", + "y" : 95, + "name" : "#014" + }, + { + "drilldown" : "015", + "y" : 91, + "name" : "#015" + }, + { + "y" : 65, + "name" : "#016", + "drilldown" : "016" + }, + { + "drilldown" : "017", + "y" : 78, + "name" : "#017" + }, + { + "drilldown" : "018", + "name" : "#018", + "y" : 74 + }, + { + "drilldown" : "019", + "name" : "#019", + "y" : 93 + }, + { + "y" : 92, + "name" : "#020", + "drilldown" : "020" + }, + { + "name" : "#021", + "y" : 64, + "drilldown" : "021" + }, + { + "name" : "#022", + "y" : 13, + "drilldown" : "022" + } + ], + "colorByPoint" : "true" + } + ], + "chart" : { + "type" : "column" + }, "drilldown" : { "series" : [ { - "id" : "001", + "name" : "001", "data" : [ [ "Perl 5", @@ -45,11 +141,10 @@ 10 ] ], - "name" : "001" + "id" : "001" }, { "id" : "002", - "name" : "002", "data" : [ [ "Perl 5", @@ -63,10 +158,10 @@ "Blog", 9 ] - ] + ], + "name" : "002" }, { - "id" : "003", "data" : [ [ "Perl 5", @@ -81,10 +176,12 @@ 8 ] ], + "id" : "003", "name" : "003" }, { "name" : "004", + "id" : "004", "data" : [ [ "Perl 5", @@ -98,8 +195,7 @@ "Blog", 9 ] - ], - "id" : "004" + ] }, { "name" : "005", @@ -121,7 +217,6 @@ }, { "id" : "006", - "name" : "006", "data" : [ [ "Perl 5", @@ -135,10 +230,10 @@ "Blog", 6 ] - ] + ], + "name" : "006" }, { - "id" : "007", "name" : "007", "data" : [ [ @@ -153,9 +248,11 @@ "Blog", 9 ] - ] + ], + "id" : "007" }, { + "name" : "008", "data" : [ [ "Perl 5", @@ -170,11 +267,10 @@ 10 ] ], - "name" : "008", "id" : "008" }, { - "id" : "009", + "name" : "009", "data" : [ [ "Perl 5", @@ -189,11 +285,10 @@ 12 ] ], - "name" : "009" + "id" : "009" }, { "id" : "010", - "name" : "010", "data" : [ [ "Perl 5", @@ -207,10 +302,10 @@ "Blog", 10 ] - ] + ], + "name" : "010" }, { - "name" : "011", "data" : [ [ "Perl 5", @@ -225,9 +320,11 @@ 9 ] ], - "id" : "011" + "id" : "011", + "name" : "011" }, { + "id" : "012", "data" : [ [ "Perl 5", @@ -242,11 +339,11 @@ 10 ] ], - "name" : "012", - "id" : "012" + "name" : "012" }, { "name" : "013", + "id" : "013", "data" : [ [ "Perl 5", @@ -260,11 +357,10 @@ "Blog", 12 ] - ], - "id" : "013" + ] }, { - "id" : "014", + "name" : "014", "data" : [ [ "Perl 5", @@ -279,10 +375,10 @@ 14 ] ], - "name" : "014" + "id" : "014" }, { - "name" : "015", + "id" : "015", "data" : [ [ "Perl 5", @@ -297,7 +393,7 @@ 13 ] ], - "id" : "015" + "name" : "015" }, { "name" : "016", @@ -318,7 +414,6 @@ "id" : "016" }, { - "id" : "017", "name" : "017", "data" : [ [ @@ -333,10 +428,10 @@ "Blog", 11 ] - ] + ], + "id" : "017" }, { - "id" : "018", "data" : [ [ "Perl 5", @@ -351,6 +446,7 @@ 12 ] ], + "id" : "018", "name" : "018" }, { @@ -368,10 +464,12 @@ 11 ] ], - "name" : "019", - "id" : "019" + "id" : "019", + "name" : "019" }, { + "name" : "020", + "id" : "020", "data" : [ [ "Perl 5", @@ -385,13 +483,10 @@ "Blog", 12 ] - ], - "name" : "020", - "id" : "020" + ] }, { "id" : "021", - "name" : "021", "data" : [ [ "Perl 5", @@ -405,150 +500,55 @@ "Blog", 7 ] - ] + ], + "name" : "021" }, { + "id" : "022", "data" : [ [ "Perl 5", - 4 + 6 ], [ "Perl 6", - 4 + 6 ], [ "Blog", - 0 + 1 ] ], - "name" : "022", - "id" : "022" + "name" : "022" } ] }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "tooltip" : { + "headerFormat" : "<span style=\"font-size:11px\"></span>", + "pointFormat" : "<span style=\"color:{point.color}\">Challenge {point.name}</span>: <b>{point.y:f}</b><br/>", + "followPointer" : "true" + }, + "subtitle" : { + "text" : "Click the columns to drilldown the language breakdown. Last updated at 2019-08-22 12:02:23 GMT" + }, + "xAxis" : { + "type" : "category" + }, "title" : { "text" : "Perl Weekly Challenge Language" }, - "chart" : { - "type" : "column" - }, - "series" : [ - { - "name" : "Perl Weekly Challenge Languages", - "data" : [ - { - "y" : 123, - "name" : "#001", - "drilldown" : "001" - }, - { - "y" : 104, - "name" : "#002", - "drilldown" : "002" - }, - { - "drilldown" : "003", - "name" : "#003", - "y" : 66 - }, - { - "y" : 84, - "drilldown" : "004", - "name" : "#004" - }, - { - "name" : "#005", - "drilldown" : "005", - "y" : 66 - }, - { - "drilldown" : "006", - "name" : "#006", - "y" : 47 - }, - { - "y" : 55, - "name" : "#007", - "drilldown" : "007" - }, - { - "y" : 68, - "drilldown" : "008", - "name" : "#008" - }, - { - "y" : 66, - "drilldown" : "009", - "name" : "#009" - }, - { - "name" : "#010", - "drilldown" : "010", - "y" : 59 - }, - { - "y" : 78, - "name" : "#011", - "drilldown" : "011" - }, - { - "y" : 82, - "name" : "#012", - "drilldown" : "012" - }, - { - "y" : 75, - "name" : "#013", - "drilldown" : "013" - }, - { - "y" : 95, - "drilldown" : "014", - "name" : "#014" - }, - { - "name" : "#015", - "drilldown" : "015", - "y" : 91 - }, - { - "name" : "#016", - "drilldown" : "016", - "y" : 65 - }, - { - "y" : 78, - "drilldown" : "017", - "name" : "#017" - }, - { - "drilldown" : "018", - "name" : "#018", - "y" : 74 - }, - { - "drilldown" : "019", - "name" : "#019", - "y" : 93 - }, - { - "name" : "#020", - "drilldown" : "020", - "y" : 92 - }, - { - "y" : 64, - "drilldown" : "021", - "name" : "#021" - }, - { - "y" : 8, - "drilldown" : "022", - "name" : "#022" - } - ], - "colorByPoint" : "true" + "plotOptions" : { + "series" : { + "dataLabels" : { + "format" : "{point.y}", + "enabled" : 1 + }, + "borderWidth" : 0 } - ] + } } diff --git a/stats/pwc-leaders.json b/stats/pwc-leaders.json index 88d8e8e670..c36d08d047 100644 --- a/stats/pwc-leaders.json +++ b/stats/pwc-leaders.json @@ -1,383 +1,96 @@ { - "tooltip" : { - "headerFormat" : "<span style=\"font-size:11px\"></span>", - "followPointer" : "true", - "pointFormat" : "<span style=\"color:{point.color}\">{point.name}</span>: <b>{point.y:f}</b><br/>" - }, - "series" : [ - { - "colorByPoint" : "true", - "data" : [ - { - "name" : "#1: Joelle Maslak", - "drilldown" : "Joelle Maslak", - "y" : 228 - }, - { - "drilldown" : "Laurent Rosenfeld", - "name" : "#2: Laurent Rosenfeld", - "y" : 222 - }, - { - "name" : "#3: Jaldhar H. Vyas", - "drilldown" : "Jaldhar H. Vyas", - "y" : 182 - }, - { - "name" : "#4: Ruben Westerberg", - "drilldown" : "Ruben Westerberg", - "y" : 156 - }, - { - "y" : 136, - "drilldown" : "Adam Russell", - "name" : "#5: Adam Russell" - }, - { - "y" : 134, - "drilldown" : "Athanasius", - "name" : "#6: Athanasius" - }, - { - "name" : "#7: Arne Sommer", - "drilldown" : "Arne Sommer", - "y" : 118 - }, - { - "drilldown" : "Kian-Meng Ang", - "name" : "#8: Kian-Meng Ang", - "y" : 118 - }, - { - "drilldown" : "E. Choroba", - "name" : "#9: E. Choroba", - "y" : 102 - }, - { - "drilldown" : "Simon Proctor", - "name" : "#10: Simon Proctor", - "y" : 94 - }, - { - "y" : 92, - "drilldown" : "Francis Whittle", - "name" : "#11: Francis Whittle" - }, - { - "y" : 90, - "name" : "#12: Dave Jacoby", - |
