diff options
| author | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-04-30 08:32:08 +0100 |
|---|---|---|
| committer | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-04-30 08:32:08 +0100 |
| commit | fe37613a7bb2c8eb6dc234d2931212692048be18 (patch) | |
| tree | fab0579dcafb6ba348d61ef78e5c1e6cc50f2c08 | |
| parent | a16598e75adf8297d906b8e15607c7b2c0856d01 (diff) | |
| download | perlweeklychallenge-club-fe37613a7bb2c8eb6dc234d2931212692048be18.tar.gz perlweeklychallenge-club-fe37613a7bb2c8eb6dc234d2931212692048be18.tar.bz2 perlweeklychallenge-club-fe37613a7bb2c8eb6dc234d2931212692048be18.zip | |
- Added Raku solutions to Compare Version task.
| -rw-r--r-- | challenge-058/mohammad-anwar/perl/ch-1a.pl | 12 | ||||
| -rw-r--r-- | challenge-058/mohammad-anwar/raku/ch-1.p6 | 64 | ||||
| -rw-r--r-- | challenge-058/mohammad-anwar/raku/ch-1a.p6 | 69 | ||||
| -rw-r--r-- | stats/pwc-current.json | 118 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown-summary.json | 80 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown.json | 848 | ||||
| -rw-r--r-- | stats/pwc-leaders.json | 732 | ||||
| -rw-r--r-- | stats/pwc-summary-1-30.json | 120 | ||||
| -rw-r--r-- | stats/pwc-summary-121-150.json | 122 | ||||
| -rw-r--r-- | stats/pwc-summary-151-180.json | 46 | ||||
| -rw-r--r-- | stats/pwc-summary-31-60.json | 120 | ||||
| -rw-r--r-- | stats/pwc-summary-61-90.json | 56 | ||||
| -rw-r--r-- | stats/pwc-summary-91-120.json | 46 | ||||
| -rw-r--r-- | stats/pwc-summary.json | 380 |
14 files changed, 1475 insertions, 1338 deletions
diff --git a/challenge-058/mohammad-anwar/perl/ch-1a.pl b/challenge-058/mohammad-anwar/perl/ch-1a.pl index 6591aec035..5b9013d929 100644 --- a/challenge-058/mohammad-anwar/perl/ch-1a.pl +++ b/challenge-058/mohammad-anwar/perl/ch-1a.pl @@ -5,12 +5,12 @@ use warnings; use Test::More; -is (cmp_version('0.1', '1.1'), -1, '0.1 < 1.1'); -is (cmp_version('2.0', '1.2'), 1, '2.0 > 1.2'); -is (cmp_version('1.2', '1.2_5'), -1, '1.2 < 1.2_5'); -is (cmp_version('1.2.2', '1.2_1'), 1, '1.2.2 > 1.2_1'); -is (cmp_version('1.2_1', '1.2_1'), 0, '1.2_1 = 1.2_1'); -is (cmp_version('1.2.2', '1.2_1'), 1, '1.2.2 > 1.2_1'); +is (cmp_version('0.1', '1.1'), -1, '0.1 cmp 1.1'); +is (cmp_version('2.0', '1.2'), 1, '2.0 cmp 1.2'); +is (cmp_version('1.2', '1.2_5'), -1, '1.2 cmp 1.2_5'); +is (cmp_version('1.2.2', '1.2_1'), 1, '1.2.2 cmp 1.2_1'); +is (cmp_version('1.2_1', '1.2_1'), 0, '1.2_1 cmp 1.2_1'); +is (cmp_version('1.2.1', '1.2.1'), 0, '1.2.1 cmp 1.2.1'); done_testing; diff --git a/challenge-058/mohammad-anwar/raku/ch-1.p6 b/challenge-058/mohammad-anwar/raku/ch-1.p6 new file mode 100644 index 0000000000..5811751861 --- /dev/null +++ b/challenge-058/mohammad-anwar/raku/ch-1.p6 @@ -0,0 +1,64 @@ +#!/usr/bin/env perl6 + +use v6.d; + +sub MAIN(Str :$v1 = '0.1', Str :$v2 = '1.1') { + say sprintf("%s cmp %s = %s", $v1, $v2, cmp-version($v1, $v2)); +} + +sub cmp-version(Str $v1, Str $v2) { + + # Short circuit, good idea? + return 0 if ($v1 eq $v2); + + my @v1 = $v1.split("."); + my @v2 = $v2.split("."); + + my $max = @v1.elems > @v2.elems ?? @v1.elems !! @v2.elems; + my $i = 0; + + my $v1_alpha; + my $v2_alpha; + + while $i < $max { + @v1[$i] = 0 unless defined @v1[$i]; + @v2[$i] = 0 unless defined @v2[$i]; + + if @v1[$i] ~~ / <[_]> / { + (@v1[$i], $v1_alpha) = @v1[$i].split("_"); + } + if @v2[$i] ~~ / <[_]> / { + (@v2[$i], $v2_alpha) = @v2[$i].split("_"); + } + + if defined @v1[$i] && defined @v2[$i] { + if @v1[$i] > @v2[$i] { + return 1; + } + elsif @v1[$i] < @v2[$i] { + return -1; + } + } + + $i++; + } + + if defined $v1_alpha && defined $v2_alpha { + if $v1_alpha > $v2_alpha { + return 1; + } + elsif $v1_alpha < $v2_alpha { + return -1; + } + } + else { + if defined $v1_alpha { + return 1; + } + if defined $v2_alpha { + return -1; + } + } + + return 0; +} diff --git a/challenge-058/mohammad-anwar/raku/ch-1a.p6 b/challenge-058/mohammad-anwar/raku/ch-1a.p6 new file mode 100644 index 0000000000..7c58a6dbef --- /dev/null +++ b/challenge-058/mohammad-anwar/raku/ch-1a.p6 @@ -0,0 +1,69 @@ +#!/usr/bin/env perl6 + +use Test; + +is cmp-version('0.1', '1.1'), -1, '0.1 cmp 1.1'; +is cmp-version('2.0', '1.2'), 1, '2.0 cmp 1.2'; +is cmp-version('1.2', '1.2_5'), -1, '1.2 cmp 1.2_5'; +is cmp-version('1.2.2', '1.2_1'), 1, '1.2.2 cmp 1.2_1'; +is cmp-version('1.2_1', '1.2_1'), 0, '1.2_1 cmp 1.2_1'; +is cmp-version('1.2.1', '1.2.1'), 0, '1.2.1 cmp 1.2.1'; + +done-testing; + +sub cmp-version(Str $v1, Str $v2) { + + # Short circuit, good idea? + return 0 if ($v1 eq $v2); + + my @v1 = $v1.split("."); + my @v2 = $v2.split("."); + + my $max = @v1.elems > @v2.elems ?? @v1.elems !! @v2.elems; + my $i = 0; + + my $v1_alpha; + my $v2_alpha; + + while $i < $max { + @v1[$i] = 0 unless defined @v1[$i]; + @v2[$i] = 0 unless defined @v2[$i]; + + if @v1[$i] ~~ / <[_]> / { + (@v1[$i], $v1_alpha) = @v1[$i].split("_"); + } + if @v2[$i] ~~ / <[_]> / { + (@v2[$i], $v2_alpha) = @v2[$i].split("_"); + } + + if defined @v1[$i] && defined @v2[$i] { + if @v1[$i] > @v2[$i] { + return 1; + } + elsif @v1[$i] < @v2[$i] { + return -1; + } + } + + $i++; + } + + if defined $v1_alpha && defined $v2_alpha { + if $v1_alpha > $v2_alpha { + return 1; + } + elsif $v1_alpha < $v2_alpha { + return -1; + } + } + else { + if defined $v1_alpha { + return 1; + } + if defined $v2_alpha { + return -1; + } + } + + return 0; +} diff --git a/stats/pwc-current.json b/stats/pwc-current.json index d85d8aa479..6f2ebb3a05 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,34 +1,30 @@ { - "legend" : { - "enabled" : 0 - }, - "xAxis" : { - "type" : "category" + "subtitle" : { + "text" : "[Champions: 11] Last updated at 2020-04-30 07:31:27 GMT" }, "drilldown" : { "series" : [ { "id" : "Cheok-Yin Fung", - "name" : "Cheok-Yin Fung", "data" : [ [ "Perl", 1 ] - ] + ], + "name" : "Cheok-Yin Fung" }, { - "name" : "E. Choroba", "data" : [ [ "Perl", 2 ] ], - "id" : "E. Choroba" + "id" : "E. Choroba", + "name" : "E. Choroba" }, { - "id" : "Javier Luque", "data" : [ [ "Perl", @@ -43,20 +39,20 @@ 1 ] ], + "id" : "Javier Luque", "name" : "Javier Luque" }, { - "id" : "Jorg Sommrey", + "name" : "Jorg Sommrey", "data" : [ [ "Perl", 1 ] ], - "name" : "Jorg Sommrey" + "id" : "Jorg Sommrey" }, { - "name" : "Luca Ferrari", "data" : [ [ "Raku", @@ -67,56 +63,61 @@ 2 ] ], - "id" : "Luca Ferrari" + "id" : "Luca Ferrari", + "name" : "Luca Ferrari" }, { - "name" : "Mark Anderson", + "id" : "Mark Anderson", "data" : [ [ "Raku", 2 ] ], - "id" : "Mark Anderson" + "name" : "Mark Anderson" }, { "id" : "Mohammad S Anwar", - "name" : "Mohammad S Anwar", "data" : [ [ "Perl", 2 + ], + [ + "Raku", + 1 ] - ] + ], + "name" : "Mohammad S Anwar" }, { - "id" : "Roger Bell_West", + "name" : "Roger Bell_West", "data" : [ [ "Perl", 2 ] ], - "name" : "Roger Bell_West" + "id" : "Roger Bell_West" }, { - "id" : "Simon Proctor", "data" : [ [ "Raku", 1 ] ], + "id" : "Simon Proctor", "name" : "Simon Proctor" }, { - "id" : "Wanderdoc", "data" : [ [ "Perl", 2 ] ], + "id" : "Wanderdoc", "name" : "Wanderdoc" }, { @@ -137,6 +138,9 @@ "title" : { "text" : "Perl Weekly Challenge - 058" }, + "legend" : { + "enabled" : 0 + }, "yAxis" : { "title" : { "text" : "Total Solutions" @@ -144,82 +148,82 @@ }, "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 + "followPointer" : 1, + "headerFormat" : "<span style='font-size:11px'>{series.name}</span><br/>" + }, + "plotOptions" : { + "series" : { + "dataLabels" : { + "format" : "{point.y}", + "enabled" : 1 + }, + "borderWidth" : 0 + } }, "series" : [ { "data" : [ { + "y" : 1, "drilldown" : "Cheok-Yin Fung", - "name" : "Cheok-Yin Fung", - "y" : 1 + "name" : "Cheok-Yin Fung" }, { "y" : 2, - "name" : "E. Choroba", - "drilldown" : "E. Choroba" + "drilldown" : "E. Choroba", + "name" : "E. Choroba" }, { - "name" : "Javier Luque", "y" : 5, - "drilldown" : "Javier Luque" + "drilldown" : "Javier Luque", + "name" : "Javier Luque" }, { + "name" : "Jorg Sommrey", "drilldown" : "Jorg Sommrey", - "y" : 1, - "name" : "Jorg Sommrey" + "y" : 1 }, { - "drilldown" : "Luca Ferrari", + "y" : 4, "name" : "Luca Ferrari", - "y" : 4 + "drilldown" : "Luca Ferrari" }, { - "drilldown" : "Mark Anderson", "y" : 2, - "name" : "Mark Anderson" + "name" : "Mark Anderson", + "drilldown" : "Mark Anderson" }, { - "name" : "Mohammad S Anwar", - "y" : 2, - "drilldown" : "Mohammad S Anwar" + "y" : 3, + "drilldown" : "Mohammad S Anwar", + "name" : "Mohammad S Anwar" }, { - "drilldown" : "Roger Bell_West", + "y" : 2, "name" : "Roger Bell_West", - "y" : 2 + "drilldown" : "Roger Bell_West" }, { - "drilldown" : "Simon Proctor", "y" : 1, + "drilldown" : "Simon Proctor", "name" : "Simon Proctor" }, { "y" : 2, - "name" : "Wanderdoc", - "drilldown" : "Wanderdoc" + "drilldown" : "Wanderdoc", + "name" : "Wanderdoc" }, { - "drilldown" : "Yet Ebreo", "y" : 2, - "name" : "Yet Ebreo" + "name" : "Yet Ebreo", + "drilldown" : "Yet Ebreo" } ], "name" : "Perl Weekly Challenge - 058", "colorByPoint" : 1 } ], - "subtitle" : { - "text" : "[Champions: 11] Last updated at 2020-04-30 06:45:46 GMT" - }, - "plotOptions" : { - "series" : { - "borderWidth" : 0, - "dataLabels" : { - "enabled" : 1, - "format" : "{point.y}" - } - } + "xAxis" : { + "type" : "category" } } diff --git a/stats/pwc-language-breakdown-summary.json b/stats/pwc-language-breakdown-summary.json index 12e3bdc8b8..150a0a8dca 100644 --- a/stats/pwc-language-breakdown-summary.json +++ b/stats/pwc-language-breakdown-summary.json @@ -1,19 +1,27 @@ { + "chart" : { + "type" : "column" + }, + "subtitle" : { + "text" : "Last updated at 2020-04-30 07:31:27 GMT" + }, + "tooltip" : { + "pointFormat" : "<b>{point.y:.0f}</b>" + }, + "legend" : { + "enabled" : "false" + }, + "yAxis" : { + "min" : 0, + "title" : { + "text" : null + } + }, + "title" : { + "text" : "Perl Weekly Challenge Contributions [2019 - 2020]" + }, "series" : [ { - "dataLabels" : { - "enabled" : "true", - "rotation" : -90, - "style" : { - "fontSize" : "13px", - "fontFamily" : "Verdana, sans-serif" - }, - "y" : 10, - "color" : "#FFFFFF", - "align" : "right", - "format" : "{point.y:.0f}" - }, - "name" : "Contributions", "data" : [ [ "Blog", @@ -25,39 +33,31 @@ ], [ "Raku", - 1528 + 1529 ] - ] + ], + "dataLabels" : { + "enabled" : "true", + "color" : "#FFFFFF", + "y" : 10, + "align" : "right", + "format" : "{point.y:.0f}", + "rotation" : -90, + "style" : { + "fontSize" : "13px", + "fontFamily" : "Verdana, sans-serif" + } + }, + "name" : "Contributions" } ], - "tooltip" : { - "pointFormat" : "<b>{point.y:.0f}</b>" - }, - "yAxis" : { - "min" : 0, - "title" : { - "text" : null - } - }, - "subtitle" : { - "text" : "Last updated at 2020-04-30 06:45:46 GMT" - }, - "legend" : { - "enabled" : "false" - }, "xAxis" : { + "type" : "category", "labels" : { "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" + "fontSize" : "13px", + "fontFamily" : "Verdana, sans-serif" } - }, - "type" : "category" - }, - "title" : { - "text" : "Perl Weekly Challenge Contributions [2019 - 2020]" - }, - "chart" : { - "type" : "column" + } } } diff --git a/stats/pwc-language-breakdown.json b/stats/pwc-language-breakdown.json index f0d39f6c9d..1c0679b64e 100644 --- a/stats/pwc-language-breakdown.json +++ b/stats/pwc-language-breakdown.json @@ -1,13 +1,330 @@ { - "chart" : { - "type" : "column" + "xAxis" : { + "type" : "category" + }, + "plotOptions" : { + "series" : { + "dataLabels" : { + "enabled" : 1, + "format" : "{point.y}" + }, + "borderWidth" : 0 + } + }, + "series" : [ + { + "data" : [ + { + "y" : 140, + "drilldown" : "001", + "name" : "#001" + }, + { + "y" : 109, + "drilldown" : "002", + "name" : "#002" + }, + { + "name" : "#003", + "drilldown" : "003", + "y" : 71 + }, + { + "y" : 91, + "drilldown" : "004", + "name" : "#004" + }, + { + "y" : 71, + "name" : "#005", + "drilldown" : "005" + }, + { + "name" : "#006", + "drilldown" : "006", + "y" : 52 + }, + { + "y" : 58, + "drilldown" : "007", + "name" : "#007" + }, + { + "y" : 70, + "drilldown" : "008", + "name" : "#008" + }, + { + "name" : "#009", + "drilldown" : "009", + "y" : 68 + }, + { + "drilldown" : "010", + "name" : "#010", + "y" : 60 + }, + { + "y" : 79, + "drilldown" : "011", + "name" : "#011" + }, + { + "drilldown" : "012", + "name" : "#012", + "y" : 83 + }, + { + "drilldown" : "013", + "name" : "#013", + "y" : 76 + }, + { + "y" : 96, + "name" : "#014", + "drilldown" : "014" + }, + { + "drilldown" : "015", + "name" : "#015", + "y" : 93 + }, + { + "y" : 66, + "name" : "#016", + "drilldown" : "016" + }, + { + "drilldown" : "017", + "name" : "#017", + "y" : 79 + }, + { + "y" : 76, + "name" : "#018", + "drilldown" : "018" + }, + { + "drilldown" : "019", + "name" : "#019", + "y" : 97 + }, + { + "name" : "#020", + "drilldown" : "020", + "y" : 95 + }, + { + "name" : "#021", + "drilldown" : "021", + "y" : 67 + }, + { + "drilldown" : "022", + "name" : "#022", + "y" : 63 + }, + { + "name" : "#023", + "drilldown" : "023", + "y" : 91 + }, + { + "y" : 70, + "name" : "#024", + "drilldown" : "024" + }, + { + "drilldown" : "025", + "name" : "#025", + "y" : 55 + }, + { + "drilldown" : "026", + "name" : "#026", + "y" : 70 + }, + { + "y" : 58, + "drilldown" : "027", + "name" : "#027" + }, + { + "name" : "#028", + "drilldown" : "028", + "y" : 78 + }, + { + "y" : 77, + "name" : "#029", + "drilldown" : "029" + }, + { + "name" : "#030", + "drilldown" : "030", + "y" : 115 + }, + { + "y" : 87, + "name" : "#031", + "drilldown" : "031" + }, + { + "drilldown" : "032", + "name" : "#032", + "y" : 92 + }, + { + "drilldown" : "033", + "name" : "#033", + "y" : 108 + }, + { + "drilldown" : "034", + "name" : "#034", + "y" : 62 + }, + { + "name" : "#035", + "drilldown" : "035", + "y" : 62 + }, + { + "drilldown" : "036", + "name" : "#036", + "y" : 66 + }, + { + "drilldown" : "037", + "name" : "#037", + "y" : 63 + }, + { + "name" : "#038", + "drilldown" : "038", + "y" : 65 + }, + { + "y" : 60, + "drilldown" : "039", + "name" : "#039" + }, + { + "y" : 71, + "drilldown" : "040", + "name" : "#040" + }, + { + "y" : 74, + "name" : "#041", + "drilldown" : "041" + }, + { + "drilldown" : "042", + "name" : "#042", + "y" : 88 + }, + { + "drilldown" : "043", + "name" : "#043", + "y" : 65 + }, + { + "y" : 81, + "drilldown" : "044", + "name" : "#044" + }, + { + "drilldown" : "045", + "name" : "#045", + "y" : 94 + }, + { + "drilldown" : "046", + "name" : "#046", + "y" : 85 + }, + { + "drilldown" : "047", + "name" : "#047", + "y" : 82 + }, + { + "y" : 106, + "name" : "#048", + "drilldown" : "048" + }, + { + "y" : 85, + "name" : "#049", + "drilldown" : "049" + }, + { + "y" : 96, + "name" : "#050", + "drilldown" : "050" + }, + { + "y" : 87, + "name" : "#051", + "drilldown" : "051" + }, + { + "y" : 89, + "drilldown" : "052", + "name" : "#052" + }, + { + "name" : "#053", + "drilldown" : "053", + "y" : 99 + }, + { + "y" : 97, + "name" : "#054", + "drilldown" : "054" + }, + { + "name" : "#055", + "drilldown" : "055", + "y" : 86 + }, + { + "y" : 92, + "drilldown" : "056", + "name" : "#056" + }, + { + "name" : "#057", + "drilldown" : "057", + "y" : 75 + }, + { + "drilldown" : "058", + "name" : "#058", + "y" : 25 + } + ], + "colorByPoint" : "true", + "name" : "Perl Weekly Challenge Languages" + } + ], + "legend" : { + "enabled" : "false" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "tooltip" : { + "followPointer" : "true", + "pointFormat" : "<span style=\"color:{point.color}\">Challenge {point.name}</span>: <b>{point.y:f}</b><br/>", + "headerFormat" : "<span style=\"font-size:11px\"></span>" }, "title" : { "text" : "Perl Weekly Challenge Language" }, - "xAxis" : { - "type" : "category" - }, "drilldown" : { "series" : [ { @@ -25,10 +342,11 @@ 11 ] ], - "name" : "001", - "id" : "001" + "id" : "001", + "name" : "001" }, { + "id" : "002", "data" : [ [ "Perl", @@ -43,11 +361,11 @@ 10 ] ], - "name" : "002", - "id" : "002" + "name" : "002" }, { "name" : "003", + "id" : "003", "data" : [ [ "Perl", @@ -61,8 +379,7 @@ "Blog", 9 ] - ], - "id" : "003" + ] }, { "id" : "004", @@ -83,7 +400,7 @@ "name" : "004" }, { - "name" : "005", + "id" : "005", "data" : [ [ "Perl", @@ -98,11 +415,11 @@ 12 ] ], - "id" : "005" + "name" : "005" }, { - "id" : "006", "name" : "006", + "id" : "006", "data" : [ [ "Perl", @@ -119,8 +436,6 @@ ] }, { - "id" : "007", - "name" : "007", "data" : [ [ "Perl", @@ -134,11 +449,12 @@ "Blog", 10 ] - ] + ], + "id" : "007", + "name" : "007" }, { "id" : "008", - "name" : "008", "data" : [ [ "Perl", @@ -152,10 +468,10 @@ "Blog", 12 ] - ] + ], + "name" : "008" }, { - "name" : "009", "data" : [ [ "Perl", @@ -170,11 +486,12 @@ 13 ] ], - "id" : "009" + "id" : "009", + "name" : "009" }, { - "id" : "010", "name" : "010", + "id" : "010", "data" : [ [ "Perl", @@ -191,6 +508,7 @@ ] }, { + "name" : "011", "data" : [ [ "Perl", @@ -205,10 +523,11 @@ 10 ] ], - "name" : "011", "id" : "011" }, { + "name" : "012", + "id" : "012", "data" : [ [ "Perl", @@ -222,12 +541,9 @@ "Blog", 11 ] - ], - "name" : "012", - "id" : "012" + ] }, { - "name" : "013", "data" : [ [ "Perl", @@ -242,10 +558,11 @@ 13 ] ], - "id" : "013" + "id" : "013", + "name" : "013" }, { - "name" : "014", + "id" : "014", "data" : [ [ "Perl", @@ -260,11 +577,10 @@ 15 ] ], - "id" : "014" + "name" : "014" }, { "id" : "015", - "name" : "015", "data" : [ [ "Perl", @@ -278,11 +594,10 @@ "Blog", 15 ] - ] + ], + "name" : "015" }, { - "id" : "016", - "name" : "016", "data" : [ [ "Perl", @@ -296,9 +611,12 @@ "Blog", 12 ] - ] + ], + "id" : "016", + "name" : "016" }, { + "name" : "017", "data" : [ [ "Perl", @@ -313,10 +631,10 @@ 12 ] ], - "name" : "017", "id" : "017" }, { + "id" : "018", "data" : [ [ "Perl", @@ -331,11 +649,10 @@ 14 ] ], - "name" : "018", - "id" : "018" + "name" : "018" }, |
