diff options
| author | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-04-30 05:26:30 +0100 |
|---|---|---|
| committer | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-04-30 05:26:30 +0100 |
| commit | 63ac7a86cb8872a50e141f502339b985c918cb6c (patch) | |
| tree | f2de7afe7a6014f9fe4ea59e583136350cee4312 | |
| parent | 3c598e57925743c5ddc55a13c79595e6b49e92db (diff) | |
| download | perlweeklychallenge-club-63ac7a86cb8872a50e141f502339b985c918cb6c.tar.gz perlweeklychallenge-club-63ac7a86cb8872a50e141f502339b985c918cb6c.tar.bz2 perlweeklychallenge-club-63ac7a86cb8872a50e141f502339b985c918cb6c.zip | |
- Added Perl solutions to the Ordered Lineup.
| -rw-r--r-- | challenge-058/mohammad-anwar/perl/ch-2.pl | 36 | ||||
| -rw-r--r-- | challenge-058/mohammad-anwar/perl/ch-2a.pl | 45 | ||||
| -rw-r--r-- | stats/pwc-current.json | 144 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown-summary.json | 46 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown.json | 870 | ||||
| -rw-r--r-- | stats/pwc-leaders.json | 376 | ||||
| -rw-r--r-- | stats/pwc-summary-1-30.json | 94 | ||||
| -rw-r--r-- | stats/pwc-summary-121-150.json | 38 | ||||
| -rw-r--r-- | stats/pwc-summary-151-180.json | 16 | ||||
| -rw-r--r-- | stats/pwc-summary-31-60.json | 40 | ||||
| -rw-r--r-- | stats/pwc-summary-61-90.json | 24 | ||||
| -rw-r--r-- | stats/pwc-summary-91-120.json | 110 | ||||
| -rw-r--r-- | stats/pwc-summary.json | 370 |
13 files changed, 1145 insertions, 1064 deletions
diff --git a/challenge-058/mohammad-anwar/perl/ch-2.pl b/challenge-058/mohammad-anwar/perl/ch-2.pl new file mode 100644 index 0000000000..58a8095c42 --- /dev/null +++ b/challenge-058/mohammad-anwar/perl/ch-2.pl @@ -0,0 +1,36 @@ +#!/usr/bin/perl + +use strict; +use warnings; + +my $H = [2, 6, 4, 5, 1, 3]; +my $T = [1, 0, 2, 0, 1, 2]; +my $O = order_list({ H => $H, T => $T }); + +print sprintf("\@H = (%s)\n", join(", ", @$H)); +print sprintf("\@T = (%s)\n", join(", ", @$T)); +print sprintf("\@O = (%s)\n", join(", ", @$O)); + +sub order_list { + my ($args) = @_; + + my @H = @{$args->{H}}; + my @T = @{$args->{T}}; + my $O = []; + + my $H_T = { map { $H[$_] => $T[$_] } 0 .. scalar(@H)-1 }; + foreach my $h (sort { $b <=> $a } keys %$H_T) { + + my $i = 0; + my $j = 0; + + while ($H_T->{$h} > $j) { + $j++ if ($O->[$i] > $h); + $i++; + } + + splice @$O, $i, 0, $h; + } + + return $O; +} diff --git a/challenge-058/mohammad-anwar/perl/ch-2a.pl b/challenge-058/mohammad-anwar/perl/ch-2a.pl new file mode 100644 index 0000000000..f77f9dd693 --- /dev/null +++ b/challenge-058/mohammad-anwar/perl/ch-2a.pl @@ -0,0 +1,45 @@ +#!/usr/bin/perl + +use strict; +use warnings; + +use Test::More; +use Test::Deep; + +my $unit_tests = [ + { in => { H => [2, 6, 4, 5, 1, 3], + T => [1, 0, 2, 0, 1, 2], + }, + out => [5, 1, 2, 6, 3, 4], + }, +]; + +foreach my $unit_test (@$unit_tests) { + is_deeply(order_list($unit_test->{in}), $unit_test->{out}); +} + +done_testing; + +sub order_list { + my ($args) = @_; + + my @H = @{$args->{H}}; + my @T = @{$args->{T}}; + my $O = []; + + my $H_T = { map { $H[$_] => $T[$_] } 0 .. scalar(@H)-1 }; + foreach my $h (sort { $b <=> $a } keys %$H_T) { + + my $i = 0; + my $j = 0; + + while ($H_T->{$h} > $j) { + $j++ if ($O->[$i] > $h); + $i++; + } + + splice @$O, $i, 0, $h; + } + + return $O; +} diff --git a/stats/pwc-current.json b/stats/pwc-current.json index a508ce33ad..34b1cef873 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,12 +1,23 @@ { - "chart" : { - "type" : "column" + "xAxis" : { + "type" : "category" + }, + "title" : { + "text" : "Perl Weekly Challenge - 058" + }, + "tooltip" : { + "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>", + "followPointer" : 1, + "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>" + }, + "legend" : { + "enabled" : 0 }, "drilldown" : { "series" : [ { - "name" : "Cheok-Yin Fung", "id" : "Cheok-Yin Fung", + "name" : "Cheok-Yin Fung", "data" : [ [ "Perl", @@ -15,17 +26,16 @@ ] }, { + "name" : "E. Choroba", "id" : "E. Choroba", "data" : [ [ "Perl", 2 ] - ], - "name" : "E. Choroba" + ] }, { - "id" : "Javier Luque", "data" : [ [ "Perl", @@ -40,20 +50,20 @@ 1 ] ], - "name" : "Javier Luque" + "name" : "Javier Luque", + "id" : "Javier Luque" }, { - "name" : "Jorg Sommrey", "data" : [ [ "Perl", 1 ] ], + "name" : "Jorg Sommrey", "id" : "Jorg Sommrey" }, { - "id" : "Luca Ferrari", "data" : [ [ "Raku", @@ -64,115 +74,130 @@ 2 ] ], + "id" : "Luca Ferrari", "name" : "Luca Ferrari" }, { + "id" : "Mark Anderson", + "name" : "Mark Anderson", "data" : [ [ "Raku", 2 ] - ], - "id" : "Mark Anderson", - "name" : "Mark Anderson" + ] }, { - "name" : "Mohammad S Anwar", "data" : [ [ "Perl", - 1 + 2 ] ], - "id" : "Mohammad S Anwar" + "id" : "Mohammad S Anwar", + "name" : "Mohammad S Anwar" }, { - "name" : "Roger Bell_West", - "id" : "Roger Bell_West", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "Roger Bell_West", + "id" : "Roger Bell_West" }, { + "id" : "Simon Proctor", "name" : "Simon Proctor", "data" : [ [ "Raku", 1 ] - ], - "id" : "Simon Proctor" + ] }, { "id" : "Wanderdoc", + "name" : "Wanderdoc", "data" : [ [ "Perl", 2 ] - ], - "name" : "Wanderdoc" + ] }, { - "id" : "Yet Ebreo", "data" : [ [ "Perl", 2 ] ], - "name" : "Yet Ebreo" + "name" : "Yet Ebreo", + "id" : "Yet Ebreo" } ] }, "subtitle" : { - "text" : "[Champions: 11] Last updated at 2020-04-29 18:14:52 GMT" + "text" : "[Champions: 11] Last updated at 2020-04-30 04:25:54 GMT" + }, + "plotOptions" : { + "series" : { + "borderWidth" : 0, + "dataLabels" : { + "enabled" : 1, + "format" : "{point.y}" + } + } + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } }, "series" : [ { "data" : [ { - "drilldown" : "Cheok-Yin Fung", + "y" : 1, "name" : "Cheok-Yin Fung", - "y" : 1 + "drilldown" : "Cheok-Yin Fung" }, { - "drilldown" : "E. Choroba", "y" : 2, - "name" : "E. Choroba" + "name" : "E. Choroba", + "drilldown" : "E. Choroba" }, { - "y" : 5, + "drilldown" : "Javier Luque", "name" : "Javier Luque", - "drilldown" : "Javier Luque" + "y" : 5 }, { - "drilldown" : "Jorg Sommrey", + "name" : "Jorg Sommrey", "y" : 1, - "name" : "Jorg Sommrey" + "drilldown" : "Jorg Sommrey" }, { - "name" : "Luca Ferrari", "y" : 4, + "name" : "Luca Ferrari", "drilldown" : "Luca Ferrari" }, { - "drilldown" : "Mark Anderson", "y" : 2, - "name" : "Mark Anderson" + "name" : "Mark Anderson", + "drilldown" : "Mark Anderson" }, { - "y" : 1, - "name" : "Mohammad S Anwar", - "drilldown" : "Mohammad S Anwar" + "drilldown" : "Mohammad S Anwar", + "y" : 2, + "name" : "Mohammad S Anwar" }, { - "drilldown" : "Roger Bell_West", "name" : "Roger Bell_West", - "y" : 2 + "y" : 2, + "drilldown" : "Roger Bell_West" }, { "drilldown" : "Simon Proctor", @@ -180,46 +205,21 @@ "name" : "Simon Proctor" }, { - "name" : "Wanderdoc", "y" : 2, + "name" : "Wanderdoc", "drilldown" : "Wanderdoc" }, { - "y" : 2, "name" : "Yet Ebreo", + "y" : 2, "drilldown" : "Yet Ebreo" } ], - "name" : "Perl Weekly Challenge - 058", - "colorByPoint" : 1 + "colorByPoint" : 1, + "name" : "Perl Weekly Challenge - 058" } ], - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } - }, - "xAxis" : { - "type" : "category" - }, - "legend" : { - "enabled" : 0 - }, - "title" : { - "text" : "Perl Weekly Challenge - 058" - }, - "plotOptions" : { - "series" : { - "borderWidth" : 0, - "dataLabels" : { - "format" : "{point.y}", - "enabled" : 1 - } - } - }, - "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/>" + "chart" : { + "type" : "column" } } diff --git a/stats/pwc-language-breakdown-summary.json b/stats/pwc-language-breakdown-summary.json index 860bfd43b2..5482de1e87 100644 --- a/stats/pwc-language-breakdown-summary.json +++ b/stats/pwc-language-breakdown-summary.json @@ -1,4 +1,13 @@ { + "xAxis" : { + "labels" : { + "style" : { + "fontFamily" : "Verdana, sans-serif", + "fontSize" : "13px" + } + }, + "type" : "category" + }, "tooltip" : { "pointFormat" : "<b>{point.y:.0f}</b>" }, @@ -8,29 +17,18 @@ "legend" : { "enabled" : "false" }, - "xAxis" : { - "type" : "category", - "labels" : { - "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" - } - } + "subtitle" : { + "text" : "Last updated at 2020-04-30 04:25:54 GMT" }, "yAxis" : { - "min" : 0, "title" : { "text" : null - } - }, - "chart" : { - "type" : "column" - }, - "subtitle" : { - "text" : "Last updated at 2020-04-29 18:14:52 GMT" + }, + "min" : 0 }, "series" : [ { + "name" : "Contributions", "data" : [ [ "Blog", @@ -38,26 +36,28 @@ ], [ "Perl", - 2440 + 2441 ], [ "Raku", 1525 ] ], - "name" : "Contributions", "dataLabels" : { + "enabled" : "true", "style" : { "fontSize" : "13px", "fontFamily" : "Verdana, sans-serif" }, + "y" : 10, "color" : "#FFFFFF", - "enabled" : "true", - "align" : "right", + "format" : "{point.y:.0f}", "rotation" : -90, - "y" : 10, - "format" : "{point.y:.0f}" + "align" : "right" } } - ] + ], + "chart" : { + "type" : "column" + } } diff --git a/stats/pwc-language-breakdown.json b/stats/pwc-language-breakdown.json index 5fd6806155..5f8fed71ab 100644 --- a/stats/pwc-language-breakdown.json +++ b/stats/pwc-language-breakdown.json @@ -1,8 +1,327 @@ { + "title" : { + "text" : "Perl Weekly Challenge Language" + }, + "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" + }, + "legend" : { + "enabled" : "false" + }, + "xAxis" : { + "type" : "category" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "chart" : { + "type" : "column" + }, + "series" : [ + { + "name" : "Perl Weekly Challenge Languages", + "data" : [ + { + "y" : 140, + "name" : "#001", + "drilldown" : "001" + }, + { + "y" : 109, + "name" : "#002", + "drilldown" : "002" + }, + { + "drilldown" : "003", + "name" : "#003", + "y" : 71 + }, + { + "drilldown" : "004", + "y" : 91, + "name" : "#004" + }, + { + "y" : 71, + "name" : "#005", + "drilldown" : "005" + }, + { + "drilldown" : "006", + "y" : 52, + "name" : "#006" + }, + { + "name" : "#007", + "y" : 58, + "drilldown" : "007" + }, + { + "y" : 70, + "name" : "#008", + "drilldown" : "008" + }, + { + "name" : "#009", + "y" : 68, + "drilldown" : "009" + }, + { + "drilldown" : "010", + "y" : 60, + "name" : "#010" + }, + { + "drilldown" : "011", + "y" : 79, + "name" : "#011" + }, + { + "drilldown" : "012", + "y" : 83, + "name" : "#012" + }, + { + "drilldown" : "013", + "y" : 76, + "name" : "#013" + }, + { + "name" : "#014", + "y" : 96, + "drilldown" : "014" + }, + { + "drilldown" : "015", + "y" : 93, + "name" : "#015" + }, + { + "name" : "#016", + "y" : 66, + "drilldown" : "016" + }, + { + "name" : "#017", + "y" : 79, + "drilldown" : "017" + }, + { + "drilldown" : "018", + "y" : 76, + "name" : "#018" + }, + { + "drilldown" : "019", + "y" : 97, + "name" : "#019" + }, + { + "drilldown" : "020", + "y" : 95, + "name" : "#020" + }, + { + "drilldown" : "021", + "y" : 67, + "name" : "#021" + }, + { + "drilldown" : "022", + "y" : 63, + "name" : "#022" + }, + { + "y" : 91, + "name" : "#023", + "drilldown" : "023" + }, + { + "drilldown" : "024", + "name" : "#024", + "y" : 70 + }, + { + "drilldown" : "025", + "name" : "#025", + "y" : 55 + }, + { + "drilldown" : "026", + "name" : "#026", + "y" : 70 + }, + { + "name" : "#027", + "y" : 58, + "drilldown" : "027" + }, + { + "drilldown" : "028", + "name" : "#028", + "y" : 78 + }, + { + "name" : "#029", + "y" : 77, + "drilldown" : "029" + }, + { + "drilldown" : "030", + "name" : "#030", + "y" : 115 + }, + { + "y" : 87, + "name" : "#031", + "drilldown" : "031" + }, + { + "y" : 92, + "name" : "#032", + "drilldown" : "032" + }, + { + "name" : "#033", + "y" : 108, + "drilldown" : "033" + }, + { + "name" : "#034", + "y" : 62, + "drilldown" : "034" + }, + { + "y" : 62, + "name" : "#035", + "drilldown" : "035" + }, + { + "y" : 66, + "name" : "#036", + "drilldown" : "036" + }, + { + "name" : "#037", + "y" : 63, + "drilldown" : "037" + }, + { + "name" : "#038", + "y" : 65, + "drilldown" : "038" + }, + { + "drilldown" : "039", + "y" : 60, + "name" : "#039" + }, + { + "y" : 71, + "name" : "#040", + "drilldown" : "040" + }, + { + "name" : "#041", + "y" : 74, + "drilldown" : "041" + }, + { + "drilldown" : "042", + "y" : 88, + "name" : "#042" + }, + { + "y" : 65, + "name" : "#043", + "drilldown" : "043" + }, + { + "drilldown" : "044", + "name" : "#044", + "y" : 81 + }, + { + "name" : "#045", + "y" : 94, + "drilldown" : "045" + }, + { + "y" : 83, + "name" : "#046", + "drilldown" : "046" + }, + { + "name" : "#047", + "y" : 81, + "drilldown" : "047" + }, + { + "name" : "#048", + "y" : 106, + "drilldown" : "048" + }, + { + "drilldown" : "049", + "name" : "#049", + "y" : 85 + }, + { + "drilldown" : "050", + "name" : "#050", + "y" : 96 + }, + { + "y" : 87, + "name" : "#051", + "drilldown" : "051" + }, + { + "y" : 89, + "name" : "#052", + "drilldown" : "052" + }, + { + "y" : 99, + "name" : "#053", + "drilldown" : "053" + }, + { + "drilldown" : "054", + "name" : "#054", + "y" : 97 + }, + { + "drilldown" : "055", + "y" : 86, + "name" : "#055" + }, + { + "drilldown" : "056", + "y" : 92, + "name" : "#056" + }, + { + "drilldown" : "057", + "name" : "#057", + "y" : 75 + }, + { + "drilldown" : "058", + "name" : "#058", + "y" : 24 + } + ], + "colorByPoint" : "true" + } + ], "drilldown" : { "series" : [ { - "id" : "001", "data" : [ [ "Perl", @@ -17,10 +336,12 @@ 11 ] ], - "name" : "001" + "name" : "001", + "id" : "001" }, { "name" : "002", + "id" : "002", "data" : [ [ "Perl", @@ -34,12 +355,11 @@ "Blog", 10 ] - ], - "id" : "002" + ] }, { - "name" : "003", "id" : "003", + "name" : "003", "data" : [ [ "Perl", @@ -56,7 +376,6 @@ ] }, { - "id" : "004", "data" : [ [ "Perl", @@ -71,11 +390,10 @@ 10 ] ], + "id" : "004", "name" : "004" }, { - "name" : "005", - "id" : "005", "data" : [ [ "Perl", @@ -89,7 +407,9 @@ "Blog", 12 ] - ] + ], + "name" : "005", + "id" : "005" }, { "data" : [ @@ -110,6 +430,7 @@ "name" : "006" }, { + "name" : "007", "id" : "007", "data" : [ [ @@ -124,11 +445,9 @@ "Blog", 10 ] - ], - "name" : "007" + ] }, { - "name" : "008", "data" : [ [ "Perl", @@ -143,11 +462,12 @@ 12 ] ], - "id" : "008" + "id" : "008", + "name" : "008" }, { - "name" : "009", "id" : "009", + "name" : "009", "data" : [ [ "Perl", @@ -164,7 +484,6 @@ ] }, { - "name" : "010", "data" : [ [ "Perl", @@ -179,11 +498,10 @@ 11 ] ], - "id" : "010" + "id" : "010", + "name" : "010" }, { - "name" : "011", - "id" : "011", "data" : [ [ "Perl", @@ -197,11 +515,13 @@ "Blog", 10 ] - ] + ], + "id" : "011", + "name" : "011" }, { - "name" : "012", "id" : "012", + "name" : "012", "data" : [ [ "Perl", @@ -218,7 +538,6 @@ ] }, { - "name" : "013", "data" : [ [ "Perl", @@ -233,10 +552,10 @@ 13 ] ], + "name" : "013", "id" : "013" }, { - "name" : "014", "data" : [ [ "Perl", @@ -251,10 +570,12 @@ 15 ] ], - "id" : "014" + "id" : "014", + "name" : "014" }, { "name" : "015", + "id" : "015", "data" : [ [ "Perl", @@ -268,8 +589,7 @@ "Blog", 15 ] - ], - "id" : "015" + ] }, { "name" : "016", @@ -290,7 +610,6 @@ ] }, { - "id" : "017", "data" : [ [ "Perl", @@ -305,10 +624,10 @@ 12 ] ], + "id" : "017", "name" : "017" }, { - "id" : "018", "data" : [ [ "Perl", @@ -323,10 +642,10 @@ 14 ] ], - "name" : "018" + "name" : "018", + "id" : "018" }, { - "id" : "019", "data" : [ [ "Perl", @@ -341,7 +660,8 @@ 13 ] ], - "name" : "019" + "name" : "019", + "id" : "019" }, { "data" : [ @@ -362,8 +682,6 @@ "name" : "020" }, { - "name" : "021", - "id" : "021", "data" : [ [ "Perl", @@ -377,9 +695,13 @@ "Blog", 10 ] - ] + ], + "id" : "021", + "name" : "021" }, { + "id" : "022", + "name" : "022", "data" : [ [ "Perl", @@ -393,9 +715,7 @@ "Blog", 10 ] - ], - "id" : "022", - "name" : "022" + ] }, { "name" : "023", @@ -416,8 +736,6 @@ ] }, { - "name" : "024", - "id" : "024", "data" : [ [ "Perl", @@ -431,7 +749,9 @@ "Blog", 11 ] - ] + ], + "name" : "024", + "id" : "024" }, { "data" : [ @@ -448,11 +768,12 @@ 12 ] ], - "id" : "025", - "name" : "025" + "name" : "025", + "id" : "025" }, { "id" : "026", + "name" : "026", "data" : [ [ "Perl", @@ -466,10 +787,11 @@ "Blog", 10 ] - ], - "name" : "026" + ] }, { + "name" : "027", + "id" : "027", "data" : [ [ "Perl", @@ -483,13 +805,9 @@ "Blog", 9 ] - ], - "id" : "027", - "name" : "027" + ] }, { - "name" : "028", - "id" : "028", "data" : [ [ "Perl", @@ -503,10 +821,13 @@ "Blog", 9 ] - ] + ], + "name" : "028", + "id" : "028" }, { "id" : "029", + "name" : "029", "data" : [ [ "Perl", @@ -520,10 +841,10 @@ |
