diff options
| author | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-09-24 08:16:26 +0100 |
|---|---|---|
| committer | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-09-24 08:16:26 +0100 |
| commit | fa61e79d8cd5ea9ff11e2883f4ff649fac0c4c39 (patch) | |
| tree | 3e5b228c5f7ec5e03cfac29f19f47a3b63902bbb | |
| parent | 070b9341842cb5af7a1d80cd613db851331077f3 (diff) | |
| download | perlweeklychallenge-club-fa61e79d8cd5ea9ff11e2883f4ff649fac0c4c39.tar.gz perlweeklychallenge-club-fa61e79d8cd5ea9ff11e2883f4ff649fac0c4c39.tar.bz2 perlweeklychallenge-club-fa61e79d8cd5ea9ff11e2883f4ff649fac0c4c39.zip | |
- Added solutions by Laurent Rosenfeld.
| -rw-r--r-- | challenge-079/laurent-rosenfeld/blog.txt | 1 | ||||
| -rw-r--r-- | challenge-079/laurent-rosenfeld/perl/ch-1.pl | 10 | ||||
| -rw-r--r-- | challenge-079/laurent-rosenfeld/perl/ch-2.pl | 50 | ||||
| -rw-r--r-- | challenge-079/laurent-rosenfeld/raku/ch-1.sh | 1 | ||||
| -rw-r--r-- | challenge-079/laurent-rosenfeld/raku/ch-2.raku | 32 | ||||
| -rw-r--r-- | stats/pwc-current.json | 375 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown-summary.json | 88 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown.json | 1160 | ||||
| -rw-r--r-- | stats/pwc-leaders.json | 388 | ||||
| -rw-r--r-- | stats/pwc-summary-1-30.json | 104 | ||||
| -rw-r--r-- | stats/pwc-summary-121-150.json | 100 | ||||
| -rw-r--r-- | stats/pwc-summary-151-180.json | 40 | ||||
| -rw-r--r-- | stats/pwc-summary-181-210.json | 50 | ||||
| -rw-r--r-- | stats/pwc-summary-31-60.json | 44 | ||||
| -rw-r--r-- | stats/pwc-summary-61-90.json | 106 | ||||
| -rw-r--r-- | stats/pwc-summary-91-120.json | 110 | ||||
| -rw-r--r-- | stats/pwc-summary.json | 438 |
17 files changed, 1607 insertions, 1490 deletions
diff --git a/challenge-079/laurent-rosenfeld/blog.txt b/challenge-079/laurent-rosenfeld/blog.txt new file mode 100644 index 0000000000..15f7c0b465 --- /dev/null +++ b/challenge-079/laurent-rosenfeld/blog.txt @@ -0,0 +1 @@ +http://blogs.perl.org/users/laurent_r/2020/09/perl-weekly-challenge-79-count-set-bits-and-trapped-rain-water.html diff --git a/challenge-079/laurent-rosenfeld/perl/ch-1.pl b/challenge-079/laurent-rosenfeld/perl/ch-1.pl new file mode 100644 index 0000000000..4033707433 --- /dev/null +++ b/challenge-079/laurent-rosenfeld/perl/ch-1.pl @@ -0,0 +1,10 @@ +use strict; +use warnings; +use feature "say"; + +my $n = shift; +my $sum; +for my $num (1..$n) { + $sum += $_ for split '', sprintf "%b", $num; +} +say $sum % 1000000007; diff --git a/challenge-079/laurent-rosenfeld/perl/ch-2.pl b/challenge-079/laurent-rosenfeld/perl/ch-2.pl new file mode 100644 index 0000000000..33f6f1cc2e --- /dev/null +++ b/challenge-079/laurent-rosenfeld/perl/ch-2.pl @@ -0,0 +1,50 @@ +use strict; +use warnings; +use feature "say"; + +my @a = @ARGV > 1 ? @ARGV : ( 2, 1, 4, 5, 3, 7); +draw_histo(@a); +say "Rain capacity is: ", capacity(@a); + +sub max { + my @vals = @_; + my $max = shift @vals; + for my $val (@vals) { + $max = $val if $val > $max; + } + return $max; +} + +sub min2 { + $_[0] < $_[1] ? $_[0] : $_[1]; +} + +sub draw_histo { + my @in = @_; + my $max_val = max @in; + say ""; + 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 capacity { + my @in = @_; + my $left_max = $in[0]; + my $total = 0; + for my $i (1..$#in-1) { + $left_max = $in[$i] and next if $in[$i] > $left_max; + my $right_max = max @in[$i+1..$#in]; + my $col = min2($left_max, $right_max) - $in[$i]; + next if $col < 0; + $total += $col; + } + return $total +} diff --git a/challenge-079/laurent-rosenfeld/raku/ch-1.sh b/challenge-079/laurent-rosenfeld/raku/ch-1.sh new file mode 100644 index 0000000000..c6f7baba11 --- /dev/null +++ b/challenge-079/laurent-rosenfeld/raku/ch-1.sh @@ -0,0 +1 @@ +raku -e 'say ([+] map { .fmt("%b").comb.sum }, 1..@*ARGS[0]) % 1000000007' diff --git a/challenge-079/laurent-rosenfeld/raku/ch-2.raku b/challenge-079/laurent-rosenfeld/raku/ch-2.raku new file mode 100644 index 0000000000..c7d571f9ee --- /dev/null +++ b/challenge-079/laurent-rosenfeld/raku/ch-2.raku @@ -0,0 +1,32 @@ +use v6; + +my @a = @*ARGS.elems > 1 ?? @*ARGS !! (2, 1, 4, 1, 2, 5); +draw-histo(@a); +say "Rain capacity is: ", capacity(@a); + + +sub draw-histo (@in) { + my $max-val = @in.max; + say ""; + 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, "\n"; +} + +sub capacity (@in) { + my $left-max = @in[0]; + my $total = 0; + for 1..@in.end-1 -> $i { + $left-max = @in[$i] and next if @in[$i] > $left-max; + my $right-max = max @in[$i+1..@in.end]; + my $col = min($left-max, $right-max) - @in[$i]; + $total += $col if $col > 0; + } + return $total +} diff --git a/stats/pwc-current.json b/stats/pwc-current.json index 308d661936..560451cd00 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,59 +1,194 @@ { + "legend" : { + "enabled" : 0 + }, + "plotOptions" : { + "series" : { + "borderWidth" : 0, + "dataLabels" : { + "enabled" : 1, + "format" : "{point.y}" + } + } + }, + "subtitle" : { + "text" : "[Champions: 20] Last updated at 2020-09-24 07:16:19 GMT" + }, + "series" : [ + { + "data" : [ + { + "drilldown" : "Abigail", + "y" : 2, + "name" : "Abigail" + }, + { + "drilldown" : "Andrew Shitov", + "name" : "Andrew Shitov", + "y" : 2 + }, + { + "drilldown" : "Dave Cross", + "name" : "Dave Cross", + "y" : 2 + }, + { + "y" : 2, + "name" : "Dave Jacoby", + "drilldown" : "Dave Jacoby" + }, + { + "name" : "E. Choroba", + "y" : 2, + "drilldown" : "E. Choroba" + }, + { + "y" : 4, + "name" : "Flavio Poletti", + "drilldown" : "Flavio Poletti" + }, + { + "drilldown" : "James Smith", + "name" : "James Smith", + "y" : 2 + }, + { + "drilldown" : "Kang-min Liu", + "name" : "Kang-min Liu", + "y" : 2 + }, + { + "drilldown" : "Laurent Rosenfeld", + "name" : "Laurent Rosenfeld", + "y" : 5 + }, + { + "drilldown" : "Mark Anderson", + "name" : "Mark Anderson", + "y" : 2 + }, + { + "drilldown" : "Markus Holzer", + "name" : "Markus Holzer", + "y" : 2 + }, + { + "y" : 2, + "name" : "Mohammad S Anwar", + "drilldown" : "Mohammad S Anwar" + }, + { + "drilldown" : "Myoungjin Jeon", + "y" : 1, + "name" : "Myoungjin Jeon" + }, + { + "drilldown" : "Niels van Dijke", + "y" : 2, + "name" : "Niels van Dijke" + }, + { + "drilldown" : "Nuno Vieira", + "name" : "Nuno Vieira", + "y" : 2 + }, + { + "drilldown" : "Roger Bell_West", + "y" : 5, + "name" : "Roger Bell_West" + }, + { + "y" : 2, + "name" : "Simon Proctor", + "drilldown" : "Simon Proctor" + }, + { + "drilldown" : "Steven Wilson", + "name" : "Steven Wilson", + "y" : 1 + }, + { + "y" : 3, + "name" : "Ulrich Rieke", + "drilldown" : "Ulrich Rieke" + }, + { + "name" : "Vinod Kumar K", + "y" : 1, + "drilldown" : "Vinod Kumar K" + } + ], + "name" : "Perl Weekly Challenge - 079", + "colorByPoint" : 1 + } + ], + "title" : { + "text" : "Perl Weekly Challenge - 079" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "tooltip" : { + "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>", + "followPointer" : 1, + "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>" + }, "drilldown" : { "series" : [ { - "id" : "Abigail", - "name" : "Abigail", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "Abigail", + "id" : "Abigail" }, { + "id" : "Andrew Shitov", + "name" : "Andrew Shitov", "data" : [ [ "Raku", 2 ] - ], - "name" : "Andrew Shitov", - "id" : "Andrew Shitov" + ] }, { - "name" : "Dave Cross", - "id" : "Dave Cross", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "Dave Cross", + "id" : "Dave Cross" }, { + "id" : "Dave Jacoby", "data" : [ [ "Perl", 2 ] ], - "name" : "Dave Jacoby", - "id" : "Dave Jacoby" + "name" : "Dave Jacoby" }, { - "id" : "E. Choroba", - "name" : "E. Choroba", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "E. Choroba", + "id" : "E. Choroba" }, { "id" : "Flavio Poletti", - "name" : "Flavio Poletti", "data" : [ [ "Perl", @@ -63,41 +198,50 @@ "Blog", 2 ] - ] + ], + "name" : "Flavio Poletti" }, { - "id" : "James Smith", "name" : "James Smith", "data" : [ [ "Perl", 2 ] - ] + ], + "id" : "James Smith" }, { - "id" : "Kang-min Liu", - "name" : "Kang-min Liu", "data" : [ [ "Raku", 2 ] - ] + ], + "name" : "Kang-min Liu", + "id" : "Kang-min Liu" }, { "data" : [ [ + "Perl", + 2 + ], + [ "Raku", 2 + ], + [ + "Blog", + 1 ] ], - "id" : "Mark Anderson", - "name" : "Mark Anderson" + "name" : "Laurent Rosenfeld", + "id" : "Laurent Rosenfeld" }, { - "id" : "Markus Holzer", - "name" : "Markus Holzer", + "id" : "Mark Anderson", + "name" : "Mark Anderson", "data" : [ [ "Raku", @@ -106,8 +250,17 @@ ] }, { + "data" : [ + [ + "Raku", + 2 + ] + ], + "name" : "Markus Holzer", + "id" : "Markus Holzer" + }, + { "name" : "Mohammad S Anwar", - "id" : "Mohammad S Anwar", "data" : [ [ "Perl", @@ -117,11 +270,12 @@ "Raku", 1 ] - ] + ], + "id" : "Mohammad S Anwar" }, { - "name" : "Myoungjin Jeon", "id" : "Myoungjin Jeon", + "name" : "Myoungjin Jeon", "data" : [ [ "Raku", @@ -130,14 +284,14 @@ ] }, { + "id" : "Niels van Dijke", "data" : [ [ "Perl", 2 ] ], - "name" : "Niels van Dijke", - "id" : "Niels van Dijke" + "name" : "Niels van Dijke" }, { "data" : [ @@ -146,12 +300,11 @@ 2 ] ], - "id" : "Nuno Vieira", - "name" : "Nuno Vieira" + "name" : "Nuno Vieira", + "id" : "Nuno Vieira" }, { "id" : "Roger Bell_West", - "name" : "Roger Bell_West", "data" : [ [ "Perl", @@ -165,29 +318,32 @@ "Blog", 1 ] - ] + ], + "name" : "Roger Bell_West" }, { + "id" : "Simon Proctor", + "name" : "Simon Proctor", "data" : [ [ "Raku", 2 ] - ], - "name" : "Simon Proctor", - "id" : "Simon Proctor" + ] }, { + "name" : "Steven Wilson", "data" : [ [ "Perl", 1 ] ], - "name" : "Steven Wilson", "id" : "Steven Wilson" }, { + "id" : "Ulrich Rieke", + "name" : "Ulrich Rieke", "data" : [ [ "Perl", @@ -197,157 +353,24 @@ "Raku", 2 ] - ], - "name" : "Ulrich Rieke", - "id" : "Ulrich Rieke" + ] }, { + "name" : "Vinod Kumar K", "data" : [ [ "Perl", 1 ] ], - "id" : "Vinod Kumar K", - "name" : "Vinod Kumar K" + "id" : "Vinod Kumar K" } ] }, - "series" : [ - { - "data" : [ - { - "y" : 2, - "drilldown" : "Abigail", - "name" : "Abigail" - }, - { - "drilldown" : "Andrew Shitov", - "name" : "Andrew Shitov", - "y" : 2 - }, - { - "name" : "Dave Cross", - "drilldown" : "Dave Cross", - "y" : 2 - }, - { - "name" : "Dave Jacoby", - "drilldown" : "Dave Jacoby", - "y" : 2 - }, - { - "drilldown" : "E. Choroba", - "name" : "E. Choroba", - "y" : 2 - }, - { - "y" : 4, - "name" : "Flavio Poletti", - "drilldown" : "Flavio Poletti" - }, - { - "name" : "James Smith", - "drilldown" : "James Smith", - "y" : 2 - }, - { - "y" : 2, - "drilldown" : "Kang-min Liu", - "name" : "Kang-min Liu" - }, - { - "drilldown" : "Mark Anderson", - "name" : "Mark Anderson", - "y" : 2 - }, - { - "drilldown" : "Markus Holzer", - "name" : "Markus Holzer", - "y" : 2 - }, - { - "drilldown" : "Mohammad S Anwar", - "name" : "Mohammad S Anwar", - "y" : 2 - }, - { - "drilldown" : "Myoungjin Jeon", - "name" : "Myoungjin Jeon", - "y" : 1 - }, - { - "y" : 2, - "name" : "Niels van Dijke", - "drilldown" : "Niels van Dijke" - }, - { - "y" : 2, - "name" : "Nuno Vieira", - "drilldown" : "Nuno Vieira" - }, - { - "y" : 5, - "name" : "Roger Bell_West", - "drilldown" : "Roger Bell_West" - }, - { - "drilldown" : "Simon Proctor", - "name" : "Simon Proctor", - "y" : 2 - }, - { - "name" : "Steven Wilson", - "drilldown" : "Steven Wilson", - "y" : 1 - }, - { - "drilldown" : "Ulrich Rieke", - "name" : "Ulrich Rieke", - "y" : 3 - }, - { - "name" : "Vinod Kumar K", - "drilldown" : "Vinod Kumar K", - "y" : 1 - } - ], - "colorByPoint" : 1, - "name" : "Perl Weekly Challenge - 079" - } - ], - "title" : { - "text" : "Perl Weekly Challenge - 079" - }, - "tooltip" : { - "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>", - "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>", - "followPointer" : 1 - }, - "xAxis" : { - "type" : "category" - }, - "legend" : { - "enabled" : 0 - }, "chart" : { "type" : "column" }, - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } - }, - "plotOptions" : { - "series" : { - "dataLabels" : { - "format" : "{point.y}", - "enabled" : 1 - }, - "borderWidth" : 0 - } - }, - "subtitle" : { - "text" : "[Champions: 19] Last updated at 2020-09-24 07:01:23 GMT" + "xAxis" : { + "type" : "category" } } diff --git a/stats/pwc-language-breakdown-summary.json b/stats/pwc-language-breakdown-summary.json index eee9dcfcb1..7e2fb47163 100644 --- a/stats/pwc-language-breakdown-summary.json +++ b/stats/pwc-language-breakdown-summary.json @@ -1,63 +1,63 @@ { + "xAxis" : { + "labels" : { + "style" : { + "fontFamily" : "Verdana, sans-serif", + "fontSize" : "13px" + } + }, + "type" : "category" + }, + "chart" : { + "type" : "column" + }, + "yAxis" : { + "title" : { + "text" : null + }, + "min" : 0 + }, + "tooltip" : { + "pointFormat" : "<b>{point.y:.0f}</b>" + }, + "legend" : { + "enabled" : "false" + }, + "subtitle" : { + "text" : "Last updated at 2020-09-24 07:16:19 GMT" + }, "title" : { "text" : "Perl Weekly Challenge Contributions [2019 - 2020]" }, "series" : [ { - "dataLabels" : { - "y" : 10, - "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" - }, - "format" : "{point.y:.0f}", - "align" : "right", - "rotation" : -90, - "color" : "#FFFFFF", - "enabled" : "true" - }, + "name" : "Contributions", "data" : [ [ "Blog", - 987 + 988 ], [ "Perl", - 3341 + 3343 ], [ "Raku", - 2173 + 2175 ] ], - "name" : "Contributions" - } - ], - "chart" : { - "type" : "column" - }, - "yAxis" : { - "min" : 0, - "title" : { - "text" : null - } - }, - "subtitle" : { - "text" : "Last updated at 2020-09-24 07:01:23 GMT" - }, - "xAxis" : { - "labels" : { - "style" : { - "fontSize" : "13px", - "fontFamily" : "Verdana, sans-serif" + "dataLabels" : { + "format" : "{point.y:.0f}", + "align" : "right", + "style" : { + "fontSize" : "13px", + "fontFamily" : "Verdana, sans-serif" + }, + "enabled" : "true", + "rotation" : -90, + "y" : 10, + "color" : "#FFFFFF" } - }, - "type" : "category" - }, - "tooltip" : { - "pointFormat" : "<b>{point.y:.0f}</b>" - }, - "legend" : { - "enabled" : "false" - } + } + ] } diff --git a/stats/pwc-language-breakdown.json b/stats/pwc-language-breakdown.json index acc85fad5b..9e8f5f7d89 100644 --- a/stats/pwc-language-breakdown.json +++ b/stats/pwc-language-breakdown.json @@ -1,15 +1,423 @@ { - "legend" : { - "enabled" : "false" - }, - "xAxis" : { - "type" : "category" - }, "tooltip" : { - "headerFormat" : "<span style=\"font-size:11px\"></span>", "followPointer" : "true", + "headerFormat" : "<span style=\"font-size:11px\"></span>", "pointFormat" : "<span style=\"color:{point.color}\">Challenge {point.name}</span>: <b>{point.y:f}</b><br/>" }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "title" : { + "text" : "Perl Weekly Challenge Language" + }, + "series" : [ + { + "colorByPoint" : "true", + "data" : [ + { + "y" : 142, + "name" : "#001", + "drilldown" : "001" + }, + { + "name" : "#002", + "y" : 111, + "drilldown" : "002" + }, + { + "y" : 71, + "name" : "#003", + "drilldown" : "003" + }, + { + "name" : "#004", + "y" : 91, + "drilldown" : "004" + }, + { + "drilldown" : "005", + "y" : 72, + "name" : "#005" + }, + { + "drilldown" : "006", + "name" : "#006", + "y" : 52 + }, + { + "drilldown" : "007", + "name" : "#007", + "y" : 59 + }, + { + "y" : 72, + "name" : "#008", + "drilldown" : "008" + }, + { + "y" : 70, + "name" : "#009", + "drilldown" : "009" + }, + { + "y" : 60, + "name" : "#010", + "drilldown" : "010" + }, + { + "y" : 79, + "name" : "#011", + "drilldown" : "011" + }, + { + "name" : "#012", + "y" : 83, + "drilldown" : "012" + }, + { + "drilldown" : "013", + "name" : "#013", + "y" : 78 + }, + { + "drilldown" : "014", + "name" : "#014", + "y" : 96 + }, + { + "y" : 93, + "name" : "#015", + "drilldown" : "015" + }, + { + "drilldown" : "016", + "y" : 66, + "name" : "#016" + }, + { + "drilldown" : "017", + "name" : "#017", + "y" : 79 + }, + { + "y" : 76, + "name" : "#018", + "drilldown" : "018" + }, + { + "y" : 97, + "name" : "#019", + "drilldown" : "019" + }, + { + "drilldown" : "020", + "name" : "#020", + "y" : 95 + }, + { + "y" : 67, + "name" : "#021", + "drilldown" : "021" + }, + { + "name" : "#022", + "y" : 63, + "drilldown" : "022" + }, + { + "drilldown" : "023", + "name" : "#023", + "y" : 91 + }, + { + "drilldown" : "024", + "y" : 70, + "name" : "#024" + }, + { + "drilldown" : "025", + "name" : "#025", + "y" : 55 + }, + { + "y" : 70, + "name" : "#026", + "drilldown" : "026" + }, + { + "y" : 58, + "name" : "#027", + "drilldown" : "027" + }, + { + "drilldown" : "028", + "name" : "#028", + "y" : 78 + }, + { + "drilldown" : "029", + "name" : "#029", + "y" : 77 + }, + { + "drilldown" : "030", + "y" : 115, + "name" : "#030" + }, + { + "drilldown" : "031", + "name" : "#031", + "y" : 87 + }, + { + "drilldown" : "032", + "y" : 92, + "name" : "#032" + }, + { + "y" : 108, + "name" : "#033", + "drilldown" : "033" + }, + { + "name" : "#034", + "y" : 62, + "drilldown" : "034" + }, + { + "y" : 62, + "name" : "#035", + "drilldown" : "035" + }, + { + "drilldown" : "036", + "name" : "#036", + "y" : 66 + }, + { + "name" : "#037", + "y" : 65, + "drilldown" : "037" + }, + { + "drilldown" : "038", + "name" : "#038", + "y" : 65 + }, + { + "name" : "#039", + "y" : 60, + "drilldown" : "039" + }, + { + "y" : 71, + "name" : "#040", + "drilldown" : "040" + }, + { + "drilldown" : "041", + "y" : 74, + "name" : "#041" + }, + { + "y" : 88, + "name" : "#042", + "drilldown" : "042" + }, + { + "drilldown" : "043", + "name" : "#043", + "y" : 66 + }, + { + "drilldown" : "044", + "y" : 82, + "name" : "#044" + }, + { + "name" : "#045", + "y" : 94, + "drilldown" : "045" + }, + { + "name" : "#046", + "y" : 85, + "drilldown" : "046" + }, + { + "drilldown" : "047", + "y" : 82, + "name" : "#047" + }, + { + "drilldown" : "048", + "y" : 106, + "name" : "#048" + }, + { + "drilldown" : "049", + "y" : 85, + "name" : "#049" + }, + { + "y" : 96, + "name" : "#050", |
