From 72133161c8d8f746d8fd8055de27649d454b81b8 Mon Sep 17 00:00:00 2001 From: Mohammad S Anwar Date: Fri, 28 Aug 2020 18:54:01 +0100 Subject: - Added solutions by Laurent Rosenfeld. --- challenge-075/laurent-rosenfeld/blog.txt | 1 + challenge-075/laurent-rosenfeld/gembase/ch-2.gem | 91 +++ challenge-075/laurent-rosenfeld/perl/ch-1.pl | 24 + challenge-075/laurent-rosenfeld/perl/ch-2.pl | 54 ++ challenge-075/laurent-rosenfeld/raku/ch-1.raku | 20 + challenge-075/laurent-rosenfeld/raku/ch-2.raku | 38 ++ stats/pwc-current.json | 361 ++++++----- stats/pwc-language-breakdown-summary.json | 58 +- stats/pwc-language-breakdown.json | 566 ++++++++--------- stats/pwc-leaders.json | 754 +++++++++++------------ stats/pwc-summary-1-30.json | 58 +- stats/pwc-summary-121-150.json | 18 +- stats/pwc-summary-151-180.json | 116 ++-- stats/pwc-summary-181-210.json | 58 +- stats/pwc-summary-31-60.json | 44 +- stats/pwc-summary-61-90.json | 38 +- stats/pwc-summary-91-120.json | 112 ++-- stats/pwc-summary.json | 420 ++++++------- 18 files changed, 1541 insertions(+), 1290 deletions(-) create mode 100644 challenge-075/laurent-rosenfeld/blog.txt create mode 100644 challenge-075/laurent-rosenfeld/gembase/ch-2.gem create mode 100644 challenge-075/laurent-rosenfeld/perl/ch-1.pl create mode 100644 challenge-075/laurent-rosenfeld/perl/ch-2.pl create mode 100644 challenge-075/laurent-rosenfeld/raku/ch-1.raku create mode 100644 challenge-075/laurent-rosenfeld/raku/ch-2.raku diff --git a/challenge-075/laurent-rosenfeld/blog.txt b/challenge-075/laurent-rosenfeld/blog.txt new file mode 100644 index 0000000000..acf824f3f6 --- /dev/null +++ b/challenge-075/laurent-rosenfeld/blog.txt @@ -0,0 +1 @@ +http://blogs.perl.org/users/laurent_r/2020/08/perl-weekly-challenge-75-coin-sums-and-largest-rectangle-histogram.html diff --git a/challenge-075/laurent-rosenfeld/gembase/ch-2.gem b/challenge-075/laurent-rosenfeld/gembase/ch-2.gem new file mode 100644 index 0000000000..822beabe65 --- /dev/null +++ b/challenge-075/laurent-rosenfeld/gembase/ch-2.gem @@ -0,0 +1,91 @@ +PROCEDURE_FORM MAIN (#p1) + #array(0) = 0 + if (#p1 = "") #p1 = "2,1,4,5,3,7" + ! Splits the input CSV into an #array of #count values (1-based index). + ! Arrays are global variables and cannot be passed as function parameters + #count = csv_split(#array, #p1) + #largest = 0 + #best_i = 0 + #best_j = 0 + perform LARGEST_RECT(#count, #largest, #best_i, #best_j) + #msg = "Largest rectangle is between indices " & #best_i - 1 & " and " & #best_j - 1 && + ". Area is " & #largest & "." + error /text_only (#msg) + perform DRAW_HISTO (#count) +END_FORM + +PROCEDURE_FORM LARGEST_RECT (#nb_items, #largest_area, #best_i, #best_j) + #i = 1 + while (#i < #nb_items) + #j = #i + 1 + while (#j <= #nb_items) + #k = #i + #min = #array(#k) + ! finding the minimal height within the index range + while (#k <= #j) + if (#array(#k) < #min) #min = #array(#k) + #k = #k + 1 + end_while + #area = (#j - #i + 1) * #min + if (#area > #largest_area) + #largest_area = #area + #best_i = #i + #best_j = #j + end_if + #j = #j + 1 + end_while + #i = #i + 1 +end_while +END_FORM + +PROCEDURE_FORM DRAW_HISTO (#nb_items) + #i = 1 + #max_val = #array(#i) + while (#i <= #nb_items) + if (#array(#i) > #max_val) #max_val = #array(#i) + #i = #i + 1 + end_while + #i = 1 + #line = "" + while (#i <= #nb_items) + #line = #line & " " & #array(#i) + #i = #i + 1 + end_while + error /text_only #line + #i = 1 + #line = "" + while (#i <= #nb_items) + #line = #line & " -" + #i = #i + 1 + end_while + error /text_only #line + #ordinate = #max_val + while (#ordinate >= 1) + #line = #ordinate + #i = 1 + while (#i <= #nb_items) + if (#array(#i) >= #ordinate) + #line = #line & " # " + else + #line = #line & " " + end_if + #i = #i + 1 + end_while + error /text_only #line + #ordinate = #ordinate - 1 + end_while + #line = "" + #i = 1 + while (#i <= #nb_items) + #line = #line & " =" + #i = #i + 1 + end_while + error /text_only #line + #line = "" + #i = 1 + while (#i <= #nb_items) + #line = #line & " " & #array(#i) + #i = #i + 1 + end_while + error /text_only #line +END_FORM diff --git a/challenge-075/laurent-rosenfeld/perl/ch-1.pl b/challenge-075/laurent-rosenfeld/perl/ch-1.pl new file mode 100644 index 0000000000..abcb1f394c --- /dev/null +++ b/challenge-075/laurent-rosenfeld/perl/ch-1.pl @@ -0,0 +1,24 @@ +use strict; +use warnings; +use feature "say"; + +my $target_sum = shift; +my $prev = 0; +my @coins = grep { $_ > $prev and $prev = $_} sort { $a <=> $b } @ARGV; +die "Need at least two integer values" unless @coins; +my @result; +find_sum(0, ()); +say for @result; + +sub find_sum { + my ($start, @allocated_so_far) = @_; + return if $start > $target_sum; + if ($start == $target_sum) { + push @result, join " ", @allocated_so_far; + } else { + my $last_coin = $allocated_so_far[-1] // 0; + for my $coin (grep $_ >= $last_coin, @coins) { + find_sum($start + $coin, @allocated_so_far, $coin); + } + } +} diff --git a/challenge-075/laurent-rosenfeld/perl/ch-2.pl b/challenge-075/laurent-rosenfeld/perl/ch-2.pl new file mode 100644 index 0000000000..b977b23305 --- /dev/null +++ b/challenge-075/laurent-rosenfeld/perl/ch-2.pl @@ -0,0 +1,54 @@ +use strict; +use warnings; +use feature "say"; + +my @a = @ARGV > 1 ? @ARGV : ( 2, 1, 4, 5, 3, 7); +draw_histo(@a); +my ($area, @rectangle) = largest_rect(@a); +say "Largest rectangle is @rectangle with an area of $area."; + +sub draw_histo { + my @in = @_; + my $max_val = $in[0]; + for my $i (1..$#in) { + $max_val = $in[$i] if $in[$i] > $max_val; + } + say "\n ", join " ", 0..$#in; + say " -" x scalar @in; + for my $ordinate (reverse 1..$max_val) { + print $ordinate; + for my $i (0..$#in) { + print $in[$i] >= $ordinate ? " # " : " "; + } + say ""; + } + say " =" x scalar @in; + say " ", join " ", @in; + say ""; +} + +sub min { + my @vals = @_; + my $min = shift @vals; + for my $val (@vals) { + $min = $val if $val < $min; + } + return $min; +} + +sub largest_rect { + my @in = @_; + my $largest_area = 0; + my @best_vals = (0, 0); + for my $i (0..$#in -1) { + for my $j ($i + 1..$#in) { + my $area = ($j - $i + 1) * min @in[$i..$j]; + # say "testing $i $j $area"; + if ($area > $largest_area) { + $largest_area = $area; + @best_vals = ($i, $j); + } + } + } + return $largest_area, @best_vals; +} diff --git a/challenge-075/laurent-rosenfeld/raku/ch-1.raku b/challenge-075/laurent-rosenfeld/raku/ch-1.raku new file mode 100644 index 0000000000..160c1d7640 --- /dev/null +++ b/challenge-075/laurent-rosenfeld/raku/ch-1.raku @@ -0,0 +1,20 @@ +use v6; + +my $target_sum = shift @*ARGS; +my @coins = @*ARGS.sort.squish; +my @result; +find-sum(0, []); +.say for @result; + +sub find-sum (Int $start, @allocated-so-far) { + return if $start > $target_sum; + if $start == $target_sum { + push @result, join " ", @allocated-so-far; + return; + } + my $last-coin = 0; + $last-coin = @allocated-so-far[*-1] if defined @allocated-so-far[*-1]; + for @coins.grep({$_ >= $last-coin}) -> $coin { + find-sum($start + $coin, (| @allocated-so-far, $coin)); + } +} diff --git a/challenge-075/laurent-rosenfeld/raku/ch-2.raku b/challenge-075/laurent-rosenfeld/raku/ch-2.raku new file mode 100644 index 0000000000..b1e266675d --- /dev/null +++ b/challenge-075/laurent-rosenfeld/raku/ch-2.raku @@ -0,0 +1,38 @@ +use v6; + +my @a = @*ARGS.elems > 1 ?? @*ARGS !! (2, 1, 4, 5, 3, 7); +draw-histo(@a); +my ($area, @rectangle) = largest-rect(@a); +say "Largest rectangle is @rectangle[] with an area of $area."; + + +sub draw-histo (@in) { + my $max-val = @in.max; + say " ", join " ", 0..@in.end; + say " -" x @in.elems; + for (1..$max-val).reverse -> $ordinate { + print $ordinate; + for 0..@in.end -> $i { + print @in[$i] >= $ordinate ?? " # " !! " "; + } + say ""; + } + say " =" x @in.elems; + say " ", join " ", @in; +} + +sub largest-rect (@in) { + my $largest_area = 0; + my @best-vals = 0, 0; + for 0..^@in.end -> $i { + for $i^..@in.end -> $j { + my $area = ($j - $i + 1) * @in[$i..$j].min; + # say "testing $i $j $area"; + if $area > $largest_area { + $largest_area = $area; + @best-vals = $i, $j; + } + } + } + return $largest_area, @best-vals; +} diff --git a/stats/pwc-current.json b/stats/pwc-current.json index 24928fbf32..65c5789b0a 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,147 +1,11 @@ { - "title" : { - "text" : "Perl Weekly Challenge - 075" - }, - "legend" : { - "enabled" : 0 - }, - "plotOptions" : { - "series" : { - "dataLabels" : { - "format" : "{point.y}", - "enabled" : 1 - }, - "borderWidth" : 0 - } - }, - "xAxis" : { - "type" : "category" - }, "yAxis" : { "title" : { "text" : "Total Solutions" } }, - "series" : [ - { - "name" : "Perl Weekly Challenge - 075", - "data" : [ - { - "name" : "Alex Mauney", - "drilldown" : "Alex Mauney", - "y" : 2 - }, - { - "drilldown" : "Alexander Pankoff", - "y" : 2, - "name" : "Alexander Pankoff" - }, - { - "drilldown" : "Dave Jacoby", - "y" : 2, - "name" : "Dave Jacoby" - }, - { - "drilldown" : "E. Choroba", - "y" : 2, - "name" : "E. Choroba" - }, - { - "y" : 2, - "drilldown" : "James Smith", - "name" : "James Smith" - }, - { - "drilldown" : "Jason Messer", - "y" : 2, - "name" : "Jason Messer" - }, - { - "y" : 5, - "drilldown" : "Javier Luque", - "name" : "Javier Luque" - }, - { - "drilldown" : "Jorg Sommrey", - "y" : 2, - "name" : "Jorg Sommrey" - }, - { - "drilldown" : "Lubos Kolouch", - "y" : 2, - "name" : "Lubos Kolouch" - }, - { - "y" : 4, - "drilldown" : "Luca Ferrari", - "name" : "Luca Ferrari" - }, - { - "name" : "Mark Anderson", - "y" : 2, - "drilldown" : "Mark Anderson" - }, - { - "name" : "Markus Holzer", - "y" : 2, - "drilldown" : "Markus Holzer" - }, - { - "name" : "Mohammad S Anwar", - "y" : 5, - "drilldown" : "Mohammad S Anwar" - }, - { - "y" : 4, - "drilldown" : "Myoungjin Jeon", - "name" : "Myoungjin Jeon" - }, - { - "name" : "Nuno Vieira", - "y" : 2, - "drilldown" : "Nuno Vieira" - }, - { - "y" : 2, - "drilldown" : "Pete Houston", - "name" : "Pete Houston" - }, - { - "name" : "Roger Bell_West", - "y" : 5, - "drilldown" : "Roger Bell_West" - }, - { - "drilldown" : "Simon Green", - "y" : 3, - "name" : "Simon Green" - }, - { - "name" : "Simon Proctor", - "drilldown" : "Simon Proctor", - "y" : 2 - }, - { - "name" : "Ulrich Rieke", - "y" : 2, - "drilldown" : "Ulrich Rieke" - }, - { - "name" : "Walt Mankowski", - "drilldown" : "Walt Mankowski", - "y" : 3 - } - ], - "colorByPoint" : 1 - } - ], - "chart" : { - "type" : "column" - }, - "tooltip" : { - "headerFormat" : "{series.name}
", - "pointFormat" : "{point.name}: {point.y:f}
", - "followPointer" : 1 + "legend" : { + "enabled" : 0 }, "drilldown" : { "series" : [ @@ -152,38 +16,38 @@ 2 ] ], - "id" : "Alex Mauney", - "name" : "Alex Mauney" + "name" : "Alex Mauney", + "id" : "Alex Mauney" }, { + "name" : "Alexander Pankoff", "data" : [ [ "Perl", 2 ] ], - "id" : "Alexander Pankoff", - "name" : "Alexander Pankoff" + "id" : "Alexander Pankoff" }, { + "id" : "Dave Jacoby", "data" : [ [ "Perl", 2 ] ], - "id" : "Dave Jacoby", "name" : "Dave Jacoby" }, { - "name" : "E. Choroba", - "id" : "E. Choroba", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "E. Choroba", + "id" : "E. Choroba" }, { "id" : "James Smith", @@ -206,6 +70,7 @@ ] }, { + "id" : "Javier Luque", "data" : [ [ "Perl", @@ -220,18 +85,35 @@ 1 ] ], - "name" : "Javier Luque", - "id" : "Javier Luque" + "name" : "Javier Luque" }, { + "name" : "Jorg Sommrey", "data" : [ [ "Perl", 2 ] ], - "id" : "Jorg Sommrey", - "name" : "Jorg Sommrey" + "id" : "Jorg Sommrey" + }, + { + "name" : "Laurent Rosenfeld", + "data" : [ + [ + "Perl", + 2 + ], + [ + "Raku", + 2 + ], + [ + "Blog", + 1 + ] + ], + "id" : "Laurent Rosenfeld" }, { "id" : "Lubos Kolouch", @@ -244,6 +126,7 @@ ] }, { + "id" : "Luca Ferrari", "data" : [ [ "Raku", @@ -254,30 +137,30 @@ 2 ] ], - "name" : "Luca Ferrari", - "id" : "Luca Ferrari" + "name" : "Luca Ferrari" }, { "id" : "Mark Anderson", - "name" : "Mark Anderson", "data" : [ [ "Raku", 2 ] - ] + ], + "name" : "Mark Anderson" }, { - "id" : "Markus Holzer", "name" : "Markus Holzer", "data" : [ [ "Raku", 2 ] - ] + ], + "id" : "Markus Holzer" }, { + "id" : "Mohammad S Anwar", "data" : [ [ "Perl", @@ -292,12 +175,10 @@ 1 ] ], - "name" : "Mohammad S Anwar", - "id" : "Mohammad S Anwar" + "name" : "Mohammad S Anwar" }, { "id" : "Myoungjin Jeon", - "name" : "Myoungjin Jeon", "data" : [ [ "Perl", @@ -307,7 +188,8 @@ "Raku", 2 ] - ] + ], + "name" : "Myoungjin Jeon" }, { "data" : [ @@ -320,16 +202,18 @@ "id" : "Nuno Vieira" }, { + "name" : "Pete Houston", "data" : [ [ "Perl", 2 ] ], - "id" : "Pete Houston", - "name" : "Pete Houston" + "id" : "Pete Houston" }, { + "id" : "Roger Bell_West", + "name" : "Roger Bell_West", "data" : [ [ "Perl", @@ -343,9 +227,7 @@ "Blog", 1 ] - ], - "id" : "Roger Bell_West", - "name" : "Roger Bell_West" + ] }, { "id" : "Simon Green", @@ -362,14 +244,14 @@ ] }, { - "name" : "Simon Proctor", - "id" : "Simon Proctor", "data" : [ [ "Raku", 2 ] - ] + ], + "name" : "Simon Proctor", + "id" : "Simon Proctor" }, { "id" : "Ulrich Rieke", @@ -397,7 +279,148 @@ } ] }, + "plotOptions" : { + "series" : { + "dataLabels" : { + "format" : "{point.y}", + "enabled" : 1 + }, + "borderWidth" : 0 + } + }, + "chart" : { + "type" : "column" + }, + "series" : [ + { + "colorByPoint" : 1, + "data" : [ + { + "y" : 2, + "name" : "Alex Mauney", + "drilldown" : "Alex Mauney" + }, + { + "y" : 2, + "name" : "Alexander Pankoff", + "drilldown" : "Alexander Pankoff" + }, + { + "drilldown" : "Dave Jacoby", + "name" : "Dave Jacoby", + "y" : 2 + }, + { + "drilldown" : "E. Choroba", + "name" : "E. Choroba", + "y" : 2 + }, + { + "drilldown" : "James Smith", + "y" : 2, + "name" : "James Smith" + }, + { + "y" : 2, + "name" : "Jason Messer", + "drilldown" : "Jason Messer" + }, + { + "name" : "Javier Luque", + "y" : 5, + "drilldown" : "Javier Luque" + }, + { + "y" : 2, + "name" : "Jorg Sommrey", + "drilldown" : "Jorg Sommrey" + }, + { + "drilldown" : "Laurent Rosenfeld", + "y" : 5, + "name" : "Laurent Rosenfeld" + }, + { + "y" : 2, + "name" : "Lubos Kolouch", + "drilldown" : "Lubos Kolouch" + }, + { + "name" : "Luca Ferrari", + "y" : 4, + "drilldown" : "Luca Ferrari" + }, + { + "drilldown" : "Mark Anderson", + "y" : 2, + "name" : "Mark Anderson" + }, + { + "y" : 2, + "name" : "Markus Holzer", + "drilldown" : "Markus Holzer" + }, + { + "y" : 5, + "name" : "Mohammad S Anwar", + "drilldown" : "Mohammad S Anwar" + }, + { + "y" : 4, + "name" : "Myoungjin Jeon", + "drilldown" : "Myoungjin Jeon" + }, + { + "drilldown" : "Nuno Vieira", + "name" : "Nuno Vieira", + "y" : 2 + }, + { + "drilldown" : "Pete Houston", + "name" : "Pete Houston", + "y" : 2 + }, + { + "drilldown" : "Roger Bell_West", + "y" : 5, + "name" : "Roger Bell_West" + }, + { + "name" : "Simon Green", + "y" : 3, + "drilldown" : "Simon Green" + }, + { + "drilldown" : "Simon Proctor", + "y" : 2, + "name" : "Simon Proctor" + }, + { + "y" : 2, + "name" : "Ulrich Rieke", + "drilldown" : "Ulrich Rieke" + }, + { + "y" : 3, + "name" : "Walt Mankowski", + "drilldown" : "Walt Mankowski" + } + ], + "name" : "Perl Weekly Challenge - 075" + } + ], + "title" : { + "text" : "Perl Weekly Challenge - 075" + }, + "tooltip" : { + "followPointer" : 1, + "headerFormat" : "{series.name}
", + "pointFormat" : "{point.name}: {point.y:f}
" + }, "subtitle" : { - "text" : "[Champions: 21] Last updated at 2020-08-28 16:23:18 GMT" + "text" : "[Champions: 22] Last updated at 2020-08-28 17:53:27 GMT" + }, + "xAxis" : { + "type" : "category" } } diff --git a/stats/pwc-language-breakdown-summary.json b/stats/pwc-language-breakdown-summary.json index 52dc1d5217..d72877a224 100644 --- a/stats/pwc-language-breakdown-summary.json +++ b/stats/pwc-language-breakdown-summary.json @@ -1,63 +1,63 @@ { - "title" : { - "text" : "Perl Weekly Challenge Contributions [2019 - 2020]" - }, "legend" : { "enabled" : "false" }, "yAxis" : { - "min" : 0, "title" : { "text" : null - } + }, + "min" : 0 }, "xAxis" : { + "type" : "category", "labels" : { "style" : { - "fontSize" : "13px", - "fontFamily" : "Verdana, sans-serif" + "fontFamily" : "Verdana, sans-serif", + "fontSize" : "13px" } - }, - "type" : "category" + } + }, + "title" : { + "text" : "Perl Weekly Challenge Contributions [2019 - 2020]" }, "series" : [ { "name" : "Contributions", - "dataLabels" : { - "align" : "right", - "rotation" : -90, - "enabled" : "true", - "format" : "{point.y:.0f}", - "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" - }, - "color" : "#FFFFFF", - "y" : 10 - }, "data" : [ [ "Blog", - 923 + 924 ], [ "Perl", - 3132 + 3134 ], [ "Raku", - 2035 + 2037 ] - ] + ], + "dataLabels" : { + "align" : "right", + "rotation" : -90, + "y" : 10, + "color" : "#FFFFFF", + "enabled" : "true", + "style" : { + "fontFamily" : "Verdana, sans-serif", + "fontSize" : "13px" + }, + "format" : "{point.y:.0f}" + } } ], - "chart" : { - "type" : "column" + "subtitle" : { + "text" : "Last updated at 2020-08-28 17:53:26 GMT" }, "tooltip" : { "pointFormat" : "{point.y:.0f}" }, - "subtitle" : { - "text" : "Last updated at 2020-08-28 16:23:18 GMT" + "chart" : { + "type" : "column" } } diff --git a/stats/pwc-language-breakdown.json b/stats/pwc-language-breakdown.json index 3216c947d9..8656664782 100644 --- a/stats/pwc-language-breakdown.json +++ b/stats/pwc-language-breakdown.json @@ -1,9 +1,6 @@ { - "legend" : { - "enabled" : "false" - }, - "title" : { - "text" : "Perl Weekly Challenge Language" + "xAxis" : { + "type" : "category" }, "plotOptions" : { "series" : { @@ -14,13 +11,8 @@ } } }, - "xAxis" : { - "type" : "category" - }, - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } + "chart" : { + "type" : "column" }, "series" : [ { @@ -28,143 +20,143 @@ "data" : [ { "y" : 142, - "drilldown" : "001", - "name" : "#001" + "name" : "#001", + "drilldown" : "001" }, { "y" : 109, - "drilldown" : "002", - "name" : "#002" + "name" : "#002", + "drilldown" : "002" }, { "y" : 71, - "drilldown" : "003", - "name" : "#003" + "name" : "#003", + "drilldown" : "003" }, { - "name" : "#004", "drilldown" : "004", + "name" : "#004", "y" : 91 }, { "name" : "#005", - "drilldown" : "005", - "y" : 72 + "y" : 72, + "drilldown" : "005" }, { - "y" : 52, "drilldown" : "006", + "y" : 52, "name" : "#006" }, { - "y" : 59, "drilldown" : "007", - "name" : "#007" + "name" : "#007", + "y" : 59 }, { - "y" : 72, "drilldown" : "008", + "y" : 72, "name" : "#008" }, { + "drilldown" : "009", "name" : "#009", - "y" : 68, - "drilldown" : "009" + "y" : 68 }, { "drilldown" : "010", - "y" : 60, - "name" : "#010" + "name" : "#010", + "y" : 60 }, { + "y" : 79, "name" : "#011", - "drilldown" : "011", - "y" : 79 + "drilldown" : "011" }, { "drilldown" : "012", - "y" : 83, - "name" : "#012" + "name" : "#012", + "y" : 83 }, { - "drilldown" : "013", "y" : 76, - "name" : "#013" + "name" : "#013", + "drilldown" : "013" }, { "y" : 96, - "drilldown" : "014", - "name" : "#014" + "name" : "#014", + "drilldown" : "014" }, { "drilldown" : "015", - "y" : 93, - "name" : "#015" + "name" : "#015", + "y" : 93 }, { "drilldown" : "016", - "y" : 66, - "name" : "#016" + "name" : "#016", + "y" : 66 }, { "y" : 79, - "drilldown" : "017", - "name" : "#017" + "name" : "#017", + "drilldown" : "017" }, { + "name" : "#018", "y" : 76, - "drilldown" : "018", - "name" : "#018" + "drilldown" : "018" }, { + "name" : "#019", "y" : 97, - "drilldown" : "019", - "name" : "#019" + "drilldown" : "019" }, { - "y" : 95, "drilldown" : "020", + "y" : 95, "name" : "#020" }, { - "name" : "#021", "drilldown" : "021", + "name" : "#021", "y" : 67 }, { "name" : "#022", - "drilldown" : "022", - "y" : 63 + "y" : 63, + "drilldown" : "022" }, { "drilldown" : "023", - "y" : 91, - "name" : "#023" + "name" : "#023", + "y" : 91 }, { - "y" : 70, "drilldown" : "024", + "y" : 70, "name" : "#024" }, { "name" : "#025", - "drilldown" : "025", - "y" : 55 + "y" : 55, + "drilldown" : "025" }, { - "name" : "#026", "drilldown" : "026", - "y" : 70 + "y" : 70, + "name" : "#026" }, { + "y" : 58, "name" : "#027", - "drilldown" : "027", - "y" : 58 + "drilldown" : "027" }, { - "drilldown" : "028", + "name" : "#028", "y" : 78, - "name" : "#028" + "drilldown" : "028" }, { "drilldown" : "029", @@ -172,14 +164,14 @@ "name" : "#029" }, { - "name" : "#030", + "drilldown" : "030", "y" : 115, - "drilldown" : "030" + "name" : "#030" }, { "y" : 87, - "drilldown" : "031", - "name" : "#031" + "name" : "#031", + "drilldown" : "031" }, { "name" : "#032", @@ -187,84 +179,84 @@ "drilldown" : "032" }, { - "name" : "#033", + "drilldown" : "033", "y" : 108, - "drilldown" : "033" + "name" : "#033" }, { "name" : "#034", - "drilldown" : "034", - "y" : 62 + "y" : 62, + "drilldown" : "034" }, { "drilldown" : "035", - "y" : 62, - "name" : "#035" + "name" : "#035", + "y" : 62 }, { - "drilldown" : "036", + "name" : "#036", "y" : 66, - "name" : "#036" + "drilldown" : "036" }, { - "name" : "#037", + "drilldown" : "037", "y" : 65, - "drilldown" : "037" + "name" : "#037" }, { - "drilldown" : "038", + "name" : "#038", "y" : 65, - "name" : "#038" + "drilldown" : "038" }, { - "name" : "#039", "drilldown" : "039", - "y" : 60 + "y" : 60, + "name" : "#039" }, { - "drilldown" : "040", + "name" : "#040", "y" : 71, - "name" : "#040" + "drilldown" : "040" }, { - "name" : "#041", + "drilldown" : "041", "y" : 74, - "drilldown" : "041" + "name" : "#041" }, { "name" : "#042", - "drilldown" : "042", - "y" : 88 + "y" : 88, + "drilldown" : "042" }, { + "name" : "#043", "y" : 66, - "drilldown" : "043", - "name" : "#043" + "drilldown" : "043" }, { "drilldown" : "044", - "y" : 82, - "name" : "#044" + "name" : "#044", + "y" : 82 }, { + "y" : 94, "name" : "#045", - "drilldown" : "045", - "y" : 94 + "drilldown" : "045" }, { - "name" : "#046", "y" : 85, + "name" : "#046", "drilldown" : "046" }, { "drilldown" : "047", - "y" : 82, - "name" : "#047" + "name" : "#047", + "y" : 82 }, { + "y" : 106, "name" : "#048", - "drilldown" : "048", - "y" : 106 + "drilldown" : "048" }, { "name" : "#049", @@ -273,33 +265,33 @@ }, { "drilldown" : "050", - "y" : 96, - "name" : "#050" + "name" : "#050", + "y" : 96 }, { "name" : "#051", - "drilldown" : "051", - "y" : 87 + "y" : 87, + "drilldown" : "051" }, { - "y" : 89, "drilldown" : "052", + "y" : 89, "name" : "#052" }, { + "drilldown" : "053", "name" : "#053", - "y" : 99, - "drilldown" : "053" + "y" : 99 }, { - "y" : 101, "drilldown" : "054", + "y" : 101, "name" : "#054" }, { - "y" : 86, "drilldown" : "055", - "name" : "#055" + "name" : "#055", + "y" : 86 }, { "drilldown" : "056", @@ -308,33 +300,33 @@ }, { "y" : 78, - "drilldown" : "057", - "name" : "#057" + "name" : "#057", + "drilldown" : "057" }, { "name" : "#058", - "drilldown" : "058", - "y" : 67 + "y" : 67, + "drilldown" : "058" }, { - "name" : "#059", "y" : 87, + "name" : "#059", "drilldown" : "059" }, { - "drilldown" : "060", + "name" : "#060", "y" : 83, - "name" : "#060" + "drilldown" : "060" }, { "name" : "#061", - "drilldown" : "061", - "y" : 79 + "y" : 79, + "drilldown" : "061" }, { "drilldown" : "062", - "y" : 54, - "name" : "#062" + "name" : "#062", + "y" : 54 }, { "drilldown" : "063", @@ -343,81 +335,84 @@ }, { "name" : "#064", - "drilldown" : "064", - "y" : 76 + "y" : 76, + "drilldown" : "064" }, { "drilldown" : "065", - "y" : 71, - "name" : "#065" + "name" : "#065", + "y" : 71 }, { - "name" : "#066", "drilldown" : "066", + "name" : "#066", "y" : 82 }, { + "y" : 88, "name" : "#067", - "drilldown" : "067", - "y" : 88 + "drilldown" : "067" }, { - "name" : "#068", "drilldown" : "068", - "y" : 73 + "y" : 73, + "name" : "#068" }, { - "name" : "#069", "drilldown" : "069", + "name" : "#069", "y" : 81 }, { + "y" : 91, "name" : "#070", - "drilldown" : "070", - "y" : 91 + "drilldown" : "070" }, { "drilldown" : "071", - "y" : 76, - "name" : "#071" + "name" : "#071", + "y" : 76 }, { + "drilldown" : "072", "name" : "#072", - "y" : 109, - "drilldown" : "072" + "y" : 109 }, { - "y" : 108, "drilldown" : "073", - "name" : "#073" + "name" : "#073", + "y" : 108 }, { - "name" : "#074", "drilldown" : "074", + "name" : "#074", "y" : 112 }, { - "y" : 57, - "drilldown" : "075", - "name" : "#075" + "y" : 62, + "name" : "#075", + "drilldown" : "075" } ], "name" : "Perl Weekly Challenge Languages" } ], - "chart" : { - "type" : "column" + "title" : { + "text" : "Perl Weekly Challenge Language" + }, + "subtitle" : { + "text" : "Click the columns to drilldown the language breakdown. Last updated at 2020-08-28 17:53:27 GMT" }, "tooltip" : { - "headerFormat" : "", "pointFormat" : "Challenge {point.name}: {point.y:f}
", + "headerFormat" : "", "followPointer" : "true" }, "drilldown" : { "series" : [ { - "name" : "001", "id" : "001", + "name" : "001", "data" : [ [ "Perl", @@ -434,6 +429,7 @@ ] }, { + "name" : "002", "data" : [ [ "Perl", @@ -448,12 +444,11 @@ 10 ] ], - "name" : "002", "id" : "002" }, { - "name" : "003", "id" : "003", + "name" : "003", "data" : [ [ "Perl", @@ -470,8 +465,8 @@ ] }, { - "name" : "004", "id" : "004", + "name" : "004", "data" : [ [ "Perl", @@ -488,6 +483,7 @@ ] }, { + "name" : "005", "data" : [ [ "Perl", @@ -502,12 +498,10 @@ 12 ] ], - "id" : "005", - "name" : "005" + "id" : "005" }, { "id" : "006", - "name" : "006", "data" : [ [ "Perl", @@ -521,11 +515,11 @@ "Blog", 7 ] - ] + ], + "name" : "006" }, { "name" : "007", - "id" : "007", "data" : [ [ "Perl", @@ -539,11 +533,12 @@ "Blog", 10 ] - ] + ], + "id" : "007" }, { - "name" : "008", "id" : "008", + "name" : "008", "data" : [ [ "Perl", @@ -560,6 +555,7 @@ ] }, { + "name" : "009", "data" : [ [ "Perl", @@ -574,10 +570,10 @@ 13 ] ], - "name" : "009", "id" : "009" }, { + "id" : "010", "data" : [ [ "Perl", @@ -592,10 +588,11 @@ 11 ] ], - "name" : "010", - "id" : "010" + "name" : "010" }, { + "id" : "011", + "name" : "011", "data" : [ [ "Perl", @@ -609,11 +606,10 @@ "Blog", 10 ] - ], - "id" : "011", - "name" : "011" + ] }, { + "id" : "012", "data" : [ [ "Perl", @@ -628,10 +624,10 @@ 11 ] ], - "id" : "012", "name" : "012" }, { + "id" : "013", "data" : [ [ "Perl", @@ -646,12 +642,9 @@ 13 ] ], - "id" : "013", "name" : "013" }, { - "name" : "014", - "id" : "014", "data" : [ [ "Perl", @@ -665,11 +658,13 @@ "Blog", 15 ] - ] + ], + "name" : "014", + "id" : "014" }, { - "name" : "015", "id" : "015", + "name" : "015", "data" : [ [ "Perl", @@ -686,6 +681,8 @@ ] }, { + "id" : "016", + "name" : "016", "data" : [ [ "Perl", @@ -699,13 +696,11 @@ "Blog", 12 ] - ], - "id" : "016", - "name" : "016" + ] }, { - "name" : "017", "id" : "017", + "name" : "017", "data" : [ [ "Perl", @@ -722,7 +717,6 @@ ] }, { - "id" : "018", "name" : "018", "data" : [ [ @@ -737,7 +731,8 @@ "Blog", 14 ] - ] + ], + "id" : "018" }, { "data" : [ @@ -754,12 +749,12 @@ 13 ] ], - "id" : "019", - "name" : "019" + "name" : "019", + "id" : "019" }, { - "name" : "020", "id" : "020", + "name" : "020", "data" : [ [ "Perl", @@ -777,7 +772,6 @@ }, { "id" : "021", - "name" : "021", "data" : [ [ "Perl", @@ -791,11 +785,10 @@ "Blog", 10 ] - ] + ], + "name" : "021" }, { - "name" : "022", - "id" : "022", "data" : [ [ "Perl", @@ -809,9 +802,13 @@ "Blog", 10 ] - ] + ], + "name" : "022", + "id" : "022" }, { + "id" : "023", + "name" : "023", "data" : [ [ "Perl", @@ -825,11 +822,10 @@ "Blog", 12 ] - ], - "name" : "023", - "id" : "023" + ] }, { + "name" : "024", "data" : [ [ "Perl", @@ -844,10 +840,11 @@ 11 ] ], - "name" : "024", "id" : "024" }, { + "id" : "025", + "name" : "025", "data" : [ [ "Perl", @@ -861,11 +858,11 @@ "Blog", 12 ] - ], - "id" : "025", - "name" : "025" + ] }, { + "id" : "026", + "name" : "026", "data" : [ [ "Perl", @@ -879,13 +876,10 @@ "Blog", 10 ] - ], - "id" : "026", - "name" : "026" + ] }, { "name" : "027", - "id" : "027", "data" : [ [ "Perl", @@ -899,9 +893,11 @@ "Blog", 9 ] - ] + ], + "id" : "027" }, { + "name" : "028", "data" : [ [ "Perl", @@ -916,10 +912,10 @@ 9 ] ], - "name" : "028", "id" : "028" }, { + "id" : "029", "data" : [ [ "Perl", @@ -934,12 +930,11 @@ 12 ] ], - "name" : "029", - "id" : "029" + "name" : "029" }, { - "name" : "030", "id" : "030", + "name" : "030", "data" : [ [ "Perl", @@ -956,6 +951,8 @@ ] }, { + "id" : "031", + "name" : "031", "data" : [ [ "Perl", @@ -969,13 +966,9 @@ "Blog", 9 ] - ], - "name" : "031", - "id" : "031" + ] }, { - "name" : "032", - "id" : "032", "data" : [ [ "Perl", @@ -989,9 +982,12 @@ "Blog", 10 ] - ] + ], + "name" : "032", + "id" : "032" }, { + "name" : "033", "data" : [ [ "Perl", @@ -1006,12 +1002,11 @@ 10 ] ], - "id" : "033", - "name" : "033" + "id" : "033" }, { - "name" : "034", "id" : "034", + "name" : "034", "data" : [ [ "Perl", @@ -1028,6 +1023,7 @@ ] }, { + "id" : "035", "data" : [ [ "Perl", @@ -1042,12 +1038,9 @@ 9 ] ], - "id" : "035", "name" : "035" }, { - "name" : "036", - "id" : "036", "data" : [ [ "Perl", @@ -1061,9 +1054,12 @@ "Blog", 11 ] - ] + ], + "name" : "036", + "id" : "036" }, { + "id" : "037", "data" : [ [ "Perl", @@ -1078,10 +1074,10 @@ 9 ] ], - "name" : "037", - "id" : "037" + "name" : "037" }, { + "id" : "038", "data" : [ [ "Perl", @@ -1096,10 +1092,10 @@ 12 ] ], - "id" : "038", "name" : "038" }, { + "name" : "039", "data" : [ [ "Perl", @@ -1114,10 +1110,11 @@ 12 ] ], - "name" : "039", "id" : "039" }, { + "id" : "040", + "name" : "040", "data" : [ [ "Perl", @@ -1131,12 +1128,9 @@ "Blog", 10 ] - ], - "name" : "040", - "id" : "040" + ] }, { - "name" : "041", "id" : "041", "data" : [ [ @@ -1151,7 +1145,8 @@ "Blog", 9 ] - ] + ], + "name" : "041" }, { "data" : [ @@ -1168,10 +1163,11 @@ 11 ] ], - "id" : "042", - "name" : "042" + "name" : "042", + "id" : "042" }, { + "name" : "043", "data" : [ [ "Perl", @@ -1186,11 +1182,9 @@ 11 ] ], - "id" : "043", - "name" : "043" + "id" : "043" }, { - "name" : "044", "id" : "044", "data" : [ [ @@ -1205,11 +1199,10 @@ "Blog", 11 ] - ] + ], + "name" : "044" }, { - "id" : "045", - "name" : "045", "data" : [ [ "Perl", @@ -1223,11 +1216,11 @@ "Blog", 11 ] - ] + ], + "name" : "045", + "id" : "045" }, { - "id" : "046", - "name" : "046", "data" : [ [ "Perl", @@ -1241,9 +1234,13 @@ "Blog", 10 ] - ] + ], + "name" : "046", + "id" : "046" }, { + "id" : "047", + "name" : "047", "data" : [ [ "Perl", @@ -1257,9 +1254,7 @@ "Blog", 10 ] - ], - "name" : "047", - "id" : "047" + ] }, { "id" : "048", @@ -1281,7 +1276,6 @@ }, { "name" : "049", - "id" : "049", "data" : [ [ "Perl", @@ -1295,7 +1289,8 @@ "Blog", 12 ] - ] + ], + "id" : "049" }, { "id" : "050", @@ -1317,7 +1312,6 @@ }, { "id" : "051", - "name" : "051", "data" : [ [ "Perl", @@ -1331,9 +1325,11 @@ "Blog", 11 ] - ] + ], + "name" : "051" }, { + "id" : "052", "data" : [ [ "Perl", @@ -1348,8 +1344,7 @@ 14 ] ], - "name" : "052", - "id" : "052" + "name" : "052" }, { "data" : [ @@ -1366,10 +1361,11 @@ 15 ] ], - "id" : "053", - "name" : "053" + "name" : "053", + "id" : "053" }, { + "name" : "054", "data" : [ [ "Perl", @@ -1384,12 +1380,9 @@ 18 ] ], - "id" : "054", - "name" : "054" + "id" : "054" }, { - "id" : "055", - "name" : "055", "data" : [ [ "Perl", @@ -1403,9 +1396,12 @@ "Blog", 14 ] - ] + ], + "name" : "055", + "id" : "055" }, { + "name" : "056", "data" : [ [ "Perl", @@ -1420,12 +1416,11 @@ 16 ] ], - "id" : "056", - "name" : "056" + "id" : "056" }, { - "name" : "057", "id" : "057", + "name" : "057", "data" : [ [ "Perl", @@ -1460,6 +1455,8 @@ "id" : "058" }, { + "id" : "059", + "name" : "059", "data" : [ [ "Perl", @@ -1473,13 +1470,10 @@ "Blog", 16 ] - ], - "id" : "059", - "name" : "059" + ] }, { "id" : "060", - "name" : "060", "data" : [ [ "Perl", @@ -1493,10 +1487,10 @@ "Blog", 16 ] - ] + ], + "name" : "060" }, { - "id" : "061", "name" : "061", "data" : [ [ @@ -1511,9 +1505,12 @@ "Blog", 14 ] - ] + ], + "id" : "061" }, { + "id" : "062", + "name" : "062", "data" : [ [ "Perl", @@ -1527,9 +1524,7 @@ "Blog", 11 ] - ], - "id" : "062", - "name" : "062" + ] }, { "id" : "063", @@ -1550,8 +1545,6 @@ ] }, { - "name" : "064", - "id" : "064", "data" : [ [ "Perl", @@ -1565,7 +1558,9 @@ "Blog", 16 ] - ] + ], + "name" : "064", + "id" : "064" }, { "data" : [ @@ -1586,6 +1581,8 @@ "id" : "065" }, { + "id" : "066", + "name" : "066", "data" : [ [ "Perl", @@ -1599,13 +1596,9 @@ "Blog", 14 ] - ], - "name" : "066", - "id" : "066" + ] }, { - "name" : "067", - "id" : "067", "data" : [ [ "Perl", @@ -1619,11 +1612,13 @@ "Blog", 18 ] - ] + ], + "name" : "067", + "id" : "067" }, { - "name" : "068", "id" : "068", + "name" : "068", "data" : [ [ "Perl", @@ -1640,6 +1635,7 @@ ] }, { + "id" : "069", "data" : [ [ "Perl", @@ -1654,7 +1650,6 @@ 16 ] ], - "id" : "069", "name" : "069" }, { @@ -1676,7 +1671,6 @@ ] }, { - "name" : "071", "id" : "071", "data" : [ [ @@ -1691,10 +1685,10 @@ "Blog", 15 ] - ] + ], + "name" : "071" }, { - "name" : "072", "id" : "072", "data" : [ [ @@ -1709,11 +1703,11 @@ "Blog", 19 ] - ] + ], + "name" : "072" }, { "name" : "073", - "id" : "073", "data" : [ [ "Perl", @@ -1727,9 +1721,11 @@ "Blog", 17 ] - ] + ], + "id" : "073" }, { + "name" : "074", "data" : [ [ "Perl", @@ -1744,30 +1740,34 @@ 20 ] ], - "name" : "074", "id" : "074" }, { + "id" : "075", "data" : [ [ "Perl", - 32 + 34 ], [ "Raku", - 18 + 20 ], [ "Blog", - 7 + 8 ] ], - "id" : "075", "name" : "075" } ] }, - "subtitle" : { - "text" : "Click the columns to drilldown the language breakdown. Last updated at 2020-08-28 16:23:18 GMT" + "legend" : { + "enabled" : "false" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } } } diff --git a/stats/pwc-leaders.json b/stats/pwc-leaders.json index 0088d7d300..a624b3b392 100644 --- a/stats/pwc-leaders.json +++ b/stats/pwc-leaders.json @@ -1,32 +1,312 @@ { + "xAxis" : { + "type" : "category" + }, + "series" : [ + { + "colorByPoint" : "true", + "name" : "Perl Weekly Challenge Leaders", + "data" : [ + { + "drilldown" : "Laurent Rosenfeld", + "y" : 844, + "name" : "#1: Laurent Rosenfeld" + }, + { + "name" : "#2: Jaldhar H. Vyas", + "y" : 642, + "drilldown" : "Jaldhar H. Vyas" + }, + { + "y" : 520, + "name" : "#3: Roger Bell_West", + "drilldown" : "Roger Bell_West" + }, + { + "name" : "#4: Arne Sommer", + "y" : 496, + "drilldown" : "Arne Sommer" + }, + { + "drilldown" : "Ruben Westerberg", + "y" : 452, + "name" : "#5: Ruben Westerberg" + }, + { + "name" : "#6: Javier Luque", + "y" : 450, + "drilldown" : "Javier Luque" + }, + { + "name" : "#7: E. Choroba", + "y" : 388, + "drilldown" : "E. Choroba" + }, + { + "y" : 370, + "name" : "#8: Colin Crain", + "drilldown" : "Colin Crain" + }, + { + "drilldown" : "Athanasius", + "name" : "#9: Athanasius", + "y" : 360 + }, + { + "y" : 336, + "name" : "#10: Adam Russell", + "drilldown" : "Adam Russell" + }, + { + "name" : "#11: Joelle Maslak", + "y" : 334, + "drilldown" : "Joelle Maslak" + }, + { + "name" : "#12: Mohammad S Anwar", + "y" : 322, + "drilldown" : "Mohammad S Anwar" + }, + { + "y" : 292, + "name" : "#13: Simon Proctor", + "drilldown" : "Simon Proctor" + }, + { + "name" : "#14: Dave Jacoby", + "y" : 288, + "drilldown" : "Dave Jacoby" + }, + { + "y" : 278, + "name" : "#15: Ryan Thompson", + "drilldown" : "Ryan Thompson" + }, + { + "name" : "#16: Luca Ferrari", + "y" : 260, + "drilldown" : "Luca Ferrari" + }, + { + "name" : "#17: Duncan C. White", + "y" : 254, + "drilldown" : "Duncan C. White" + }, + { + "y" : 230, + "name" : "#18: Andrezgz", + "drilldown" : "Andrezgz" + }, + { + "drilldown" : "Ulrich Rieke", + "name" : "#19: Ulrich Rieke", + "y" : 230 + }, + { + "drilldown" : "Yet Ebreo", + "name" : "#20: Yet Ebreo", + "y" : 210 + }, + { + "y" : 184, + "name" : "#21: Noud Aldenhoven", + "drilldown" : "Noud Aldenhoven" + }, + { + "y" : 176, + "name" : "#22: Kevin Colyer", + "drilldown" : "Kevin Colyer" + }, + { + "y" : 162, + "name" : "#23: Kian-Meng Ang", + "drilldown" : "Kian-Meng Ang" + }, + { + "drilldown" : "Mark Anderson", + "y" : 150, + "name" : "#24: Mark Anderson" + }, + { + "y" : 146, + "name" : "#25: Markus Holzer", + "drilldown" : "Markus Holzer" + }, + { + "drilldown" : "Cheok-Yin Fung", + "name" : "#26: Cheok-Yin Fung", + "y" : 144 + }, + { + "drilldown" : "Steven Wilson", + "name" : "#27: Steven Wilson", + "y" : 144 + }, + { + "drilldown" : "Wanderdoc", + "y" : 138, + "name" : "#28: Wanderdoc" + }, + { + "y" : 136, + "name" : "#29: Duane Powell", + "drilldown" : "Duane Powell" + }, + { + "name" : "#30: Lubos Kolouch", + "y" : 130, + "drilldown" : "Lubos Kolouch" + }, + { + "y" : 116, + "name" : "#31: Shahed Nooshmand", + "drilldown" : "Shahed Nooshmand" + }, + { + "y" : 110, + "name" : "#32: Saif Ahmed", + "drilldown" : "Saif Ahmed" +