diff options
| author | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-07-08 18:13:49 +0100 |
|---|---|---|
| committer | Mohammad S Anwar <mohammad.anwar@yahoo.com> | 2020-07-08 18:13:49 +0100 |
| commit | 65a482dbc604132ef11766c0915399815421b4bf (patch) | |
| tree | 64e1fce203143f535aa30a1157b8063a7eb63aa6 | |
| parent | f1b346b4170e685c2c6229e8cb8a5b1d9fe36b2d (diff) | |
| download | perlweeklychallenge-club-65a482dbc604132ef11766c0915399815421b4bf.tar.gz perlweeklychallenge-club-65a482dbc604132ef11766c0915399815421b4bf.tar.bz2 perlweeklychallenge-club-65a482dbc604132ef11766c0915399815421b4bf.zip | |
- Added Raku solutions to the "Reorder List" task.
| -rw-r--r-- | challenge-068/mohammad-anwar/raku/ch-2.raku | 64 | ||||
| -rw-r--r-- | challenge-068/mohammad-anwar/raku/ch-2a.raku | 74 | ||||
| -rw-r--r-- | stats/pwc-current.json | 154 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown-summary.json | 66 | ||||
| -rw-r--r-- | stats/pwc-language-breakdown.json | 516 | ||||
| -rw-r--r-- | stats/pwc-leaders.json | 746 | ||||
| -rw-r--r-- | stats/pwc-summary-1-30.json | 40 | ||||
| -rw-r--r-- | stats/pwc-summary-121-150.json | 118 | ||||
| -rw-r--r-- | stats/pwc-summary-151-180.json | 88 | ||||
| -rw-r--r-- | stats/pwc-summary-31-60.json | 108 | ||||
| -rw-r--r-- | stats/pwc-summary-61-90.json | 52 | ||||
| -rw-r--r-- | stats/pwc-summary-91-120.json | 114 | ||||
| -rw-r--r-- | stats/pwc-summary.json | 390 |
13 files changed, 1334 insertions, 1196 deletions
diff --git a/challenge-068/mohammad-anwar/raku/ch-2.raku b/challenge-068/mohammad-anwar/raku/ch-2.raku new file mode 100644 index 0000000000..25b737ca8a --- /dev/null +++ b/challenge-068/mohammad-anwar/raku/ch-2.raku @@ -0,0 +1,64 @@ +#!/usr/bin/env raku + +# +# Perl Weekly Challenge - 068 +# +# Task #2: Reorder List +# +# https://perlweeklychallenge.org/blog/perl-wee +# + +class Node { + has Int $.v; + has Node $.c; + + method v() { return $!v } + multi method c() { return $!c } + multi method c(Node $c) { $!c = $c } + + method show-link() { + my $c = $!c; + my @v = ($!v); + + while defined $c { + @v.push: $c.v; + $c = $c.c; + } + + return @v.join(' -> '); + } +} + +sub MAIN(Str :$linked-list? = '1 -> 2 -> 3 -> 4 -> 5') { + reorder-list($linked-list).show-link.say; +} + +sub reorder-list(Str $linked-list is copy) { + + $linked-list ~~ s:g/\s//; + my @list = $linked-list.split('->'); + my $head = Node.new(v => @list.shift.Int); + my @link = ($head); + + # prepare singly linked list + for @list -> $v { + my $node = Node.new(v => $v.Int); + @link.tail.c($node); + @link.push: $node; + } + + # reorder linked list + my Int $min = 0; + my Int $max = (@list.elems/ 2).Int; + my Int $i = 1; + for $min .. $max-1 { + my $last = @link.pop; + @link.splice($i, 0, $last); + @link.tail.c(Node); + @link[$i - 1].c($last); + @link[$i].c(@link[$i + 1]); + $i += 2; + } + + return $head; +} diff --git a/challenge-068/mohammad-anwar/raku/ch-2a.raku b/challenge-068/mohammad-anwar/raku/ch-2a.raku new file mode 100644 index 0000000000..06c86ac3ea --- /dev/null +++ b/challenge-068/mohammad-anwar/raku/ch-2a.raku @@ -0,0 +1,74 @@ +#!/usr/bin/env raku + +# +# Perl Weekly Challenge - 068 +# +# Task #2: Reorder List +# +# https://perlweeklychallenge.org/blog/perl-wee +# + +class Node { + has Int $.v; + has Node $.c; + + method v() { return $!v } + multi method c() { return $!c } + multi method c(Node $c) { $!c = $c } + + method show-link() { + my $c = $!c; + my @v = ($!v); + + while defined $c { + @v.push: $c.v; + $c = $c.c; + } + + return @v.join(' -> '); + } +} + +use Test; + +is reorder-list('1 -> 2 -> 3 -> 4').show-link, + '1 -> 4 -> 2 -> 3', + 'testing 1 -> 2 -> 3 -> 4'; +is reorder-list('1 -> 2 -> 3 -> 4 -> 5').show-link, + '1 -> 5 -> 2 -> 4 -> 3', + 'testing 1 -> 2 -> 3 -> 4 -> 5'; +is reorder-list('1 -> 2 -> 3 -> 4 -> 5 -> 6').show-link, + '1 -> 6 -> 2 -> 5 -> 3 -> 4', + 'testing 1 -> 2 -> 3 -> 4 -> 5 -> 6'; + +done-testing; + +sub reorder-list(Str $linked-list is copy) { + + $linked-list ~~ s:g/\s//; + my @list = $linked-list.split('->'); + my $head = Node.new(v => @list.shift.Int); + my @link = ($head); + + # prepare singly linked list + for @list -> $v { + my $node = Node.new(v => $v.Int); + @link.tail.c($node); + @link.push: $node; + } + + # reorder linked list + my Int $min = 0; + my Int $max = (@list.elems/ 2).Int; + my Int $i = 1; + for $min .. $max-1 { + my $last = @link.pop; + @link.splice($i, 0, $last); + @link.tail.c(Node); + @link[$i - 1].c($last); + @link[$i].c(@link[$i + 1]); + $i += 2; + } + + return $head; +} diff --git a/stats/pwc-current.json b/stats/pwc-current.json index d3ff5013dd..bec2383aa9 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,38 +1,15 @@ { "subtitle" : { - "text" : "[Champions: 11] Last updated at 2020-07-08 07:40:46 GMT" + "text" : "[Champions: 11] Last updated at 2020-07-08 17:13:33 GMT" }, - "xAxis" : { - "type" : "category" - }, - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } - }, - "title" : { - "text" : "Perl Weekly Challenge - 068" - }, - "plotOptions" : { - "series" : { - "dataLabels" : { - "format" : "{point.y}", - "enabled" : 1 - }, - "borderWidth" : 0 - } - }, - "chart" : { - "type" : "column" - }, - "tooltip" : { - "followPointer" : 1, - "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/>" + "legend" : { + "enabled" : 0 }, "drilldown" : { "series" : [ { + "id" : "Andrew Shitov", + "name" : "Andrew Shitov", "data" : [ [ "Raku", @@ -42,21 +19,21 @@ "Blog", 1 ] - ], - "id" : "Andrew Shitov", - "name" : "Andrew Shitov" + ] }, { - "id" : "E. Choroba", - "name" : "E. Choroba", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "E. Choroba", + "id" : "E. Choroba" }, { + "id" : "Javier Luque", + "name" : "Javier Luque", "data" : [ [ "Perl", @@ -70,11 +47,10 @@ "Blog", 1 ] - ], - "id" : "Javier Luque", - "name" : "Javier Luque" + ] }, { + "name" : "Luca Ferrari", "data" : [ [ "Raku", @@ -85,12 +61,11 @@ 2 ] ], - "id" : "Luca Ferrari", - "name" : "Luca Ferrari" + "id" : "Luca Ferrari" }, { - "name" : "Mark Anderson", "id" : "Mark Anderson", + "name" : "Mark Anderson", "data" : [ [ "Raku", @@ -99,6 +74,7 @@ ] }, { + "name" : "Mohammad S Anwar", "data" : [ [ "Perl", @@ -106,50 +82,49 @@ ], [ "Raku", - 1 + 2 ] ], - "name" : "Mohammad S Anwar", "id" : "Mohammad S Anwar" }, { + "id" : "Niels van Dijke", + "name" : "Niels van Dijke", "data" : [ [ "Perl", 2 ] - ], - "name" : "Niels van Dijke", - "id" : "Niels van Dijke" + ] }, { - "id" : "Roger Bell_West", - "name" : "Roger Bell_West", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "Roger Bell_West", + "id" : "Roger Bell_West" }, { + "id" : "Simon Proctor", + "name" : "Simon Proctor", "data" : [ [ "Raku", 2 ] - ], - "name" : "Simon Proctor", - "id" : "Simon Proctor" + ] }, { + "id" : "Ulrich Rieke", "data" : [ [ "Raku", 3 ] ], - "id" : "Ulrich Rieke", "name" : "Ulrich Rieke" }, { @@ -159,27 +134,32 @@ 2 ] ], - "id" : "Walt Mankowski", - "name" : "Walt Mankowski" + "name" : "Walt Mankowski", + "id" : "Walt Mankowski" } ] }, + "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/>" + }, "series" : [ { "data" : [ { - "y" : 2, + "name" : "Andrew Shitov", "drilldown" : "Andrew Shitov", - "name" : "Andrew Shitov" + "y" : 2 }, { - "y" : 2, "name" : "E. Choroba", - "drilldown" : "E. Choroba" + "drilldown" : "E. Choroba", + "y" : 2 }, { - "name" : "Javier Luque", "drilldown" : "Javier Luque", + "name" : "Javier Luque", "y" : 5 }, { @@ -188,46 +168,66 @@ "drilldown" : "Luca Ferrari" }, { - "y" : 1, + "drilldown" : "Mark Anderson", "name" : "Mark Anderson", - "drilldown" : "Mark Anderson" + "y" : 1 }, { - "y" : 3, - "name" : "Mohammad S Anwar", - "drilldown" : "Mohammad S Anwar" + "y" : 4, + "drilldown" : "Mohammad S Anwar", + "name" : "Mohammad S Anwar" }, { - "name" : "Niels van Dijke", + "y" : 2, "drilldown" : "Niels van Dijke", - "y" : 2 + "name" : "Niels van Dijke" }, { - "drilldown" : "Roger Bell_West", + "y" : 2, "name" : "Roger Bell_West", - "y" : 2 + "drilldown" : "Roger Bell_West" }, { - "name" : "Simon Proctor", "drilldown" : "Simon Proctor", + "name" : "Simon Proctor", "y" : 2 }, { + "y" : 3, "drilldown" : "Ulrich Rieke", - "name" : "Ulrich Rieke", - "y" : 3 + "name" : "Ulrich Rieke" }, { - "drilldown" : "Walt Mankowski", + "y" : 2, "name" : "Walt Mankowski", - "y" : 2 + "drilldown" : "Walt Mankowski" } ], - "name" : "Perl Weekly Challenge - 068", - "colorByPoint" : 1 + "colorByPoint" : 1, + "name" : "Perl Weekly Challenge - 068" } ], - "legend" : { - "enabled" : 0 + "chart" : { + "type" : "column" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "title" : { + "text" : "Perl Weekly Challenge - 068" + }, + "plotOptions" : { + "series" : { + "borderWidth" : 0, + "dataLabels" : { + "format" : "{point.y}", + "enabled" : 1 + } + } + }, + "xAxis" : { + "type" : "category" } } diff --git a/stats/pwc-language-breakdown-summary.json b/stats/pwc-language-breakdown-summary.json index 5053be12cc..88a2d8d8ee 100644 --- a/stats/pwc-language-breakdown-summary.json +++ b/stats/pwc-language-breakdown-summary.json @@ -1,22 +1,15 @@ { + "subtitle" : { + "text" : "Last updated at 2020-07-08 17:13:33 GMT" + }, + "legend" : { + "enabled" : "false" + }, "tooltip" : { "pointFormat" : "<b>{point.y:.0f}</b>" }, "series" : [ { - "dataLabels" : { - "rotation" : -90, - "format" : "{point.y:.0f}", - "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" - }, - "color" : "#FFFFFF", - "enabled" : "true", - "y" : 10, - "align" : "right" - }, - "name" : "Contributions", "data" : [ [ "Blog", @@ -28,29 +21,24 @@ ], [ "Raku", - 1795 + 1796 ] - ] + ], + "name" : "Contributions", + "dataLabels" : { + "format" : "{point.y:.0f}", + "align" : "right", + "y" : 10, + "color" : "#FFFFFF", + "rotation" : -90, + "enabled" : "true", + "style" : { + "fontFamily" : "Verdana, sans-serif", + "fontSize" : "13px" + } + } } ], - "legend" : { - "enabled" : "false" - }, - "xAxis" : { - "labels" : { - "style" : { - "fontFamily" : "Verdana, sans-serif", - "fontSize" : "13px" - } - }, - "type" : "category" - }, - "subtitle" : { - "text" : "Last updated at 2020-07-08 07:40:46 GMT" - }, - "title" : { - "text" : "Perl Weekly Challenge Contributions [2019 - 2020]" - }, "yAxis" : { "min" : 0, "title" : { @@ -59,5 +47,17 @@ }, "chart" : { "type" : "column" + }, + "title" : { + "text" : "Perl Weekly Challenge Contributions [2019 - 2020]" + }, + "xAxis" : { + "labels" : { + "style" : { + "fontSize" : "13px", + "fontFamily" : "Verdana, sans-serif" + } + }, + "type" : "category" } } diff --git a/stats/pwc-language-breakdown.json b/stats/pwc-language-breakdown.json index 23a3e76bc6..20ee8cc010 100644 --- a/stats/pwc-language-breakdown.json +++ b/stats/pwc-language-breakdown.json @@ -1,37 +1,52 @@ { + "xAxis" : { + "type" : "category" + }, + "title" : { + "text" : "Perl Weekly Challenge Language" + }, + "plotOptions" : { + "series" : { + "dataLabels" : { + "format" : "{point.y}", + "enabled" : 1 + }, + "borderWidth" : 0 + } + }, "series" : [ { "name" : "Perl Weekly Challenge Languages", "data" : [ { - "name" : "#001", + "y" : 142, "drilldown" : "001", - "y" : 142 + "name" : "#001" }, { - "y" : 109, + "name" : "#002", "drilldown" : "002", - "name" : "#002" + "y" : 109 }, { + "y" : 71, "drilldown" : "003", - "name" : "#003", - "y" : 71 + "name" : "#003" }, { - "name" : "#004", + "y" : 91, "drilldown" : "004", - "y" : 91 + "name" : "#004" }, { - "y" : 72, + "name" : "#005", "drilldown" : "005", - "name" : "#005" + "y" : 72 }, { - "y" : 52, "name" : "#006", - "drilldown" : "006" + "drilldown" : "006", + "y" : 52 }, { "y" : 59, @@ -39,14 +54,14 @@ "drilldown" : "007" }, { - "y" : 72, + "drilldown" : "008", "name" : "#008", - "drilldown" : "008" + "y" : 72 }, { + "y" : 68, "name" : "#009", - "drilldown" : "009", - "y" : 68 + "drilldown" : "009" }, { "y" : 60, @@ -54,9 +69,9 @@ "drilldown" : "010" }, { - "name" : "#011", + "y" : 79, "drilldown" : "011", - "y" : 79 + "name" : "#011" }, { "y" : 83, @@ -64,23 +79,23 @@ "drilldown" : "012" }, { + "y" : 76, "drilldown" : "013", - "name" : "#013", - "y" : 76 + "name" : "#013" }, { "y" : 96, - "name" : "#014", - "drilldown" : "014" + "drilldown" : "014", + "name" : "#014" }, { - "y" : 93, + "drilldown" : "015", "name" : "#015", - "drilldown" : "015" + "y" : 93 }, { - "drilldown" : "016", "name" : "#016", + "drilldown" : "016", "y" : 66 }, { @@ -89,24 +104,24 @@ "drilldown" : "017" }, { - "y" : 76, "drilldown" : "018", - "name" : "#018" + "name" : "#018", + "y" : 76 }, { + "y" : 97, "drilldown" : "019", - "name" : "#019", - "y" : 97 + "name" : "#019" }, { "y" : 95, - "name" : "#020", - "drilldown" : "020" + "drilldown" : "020", + "name" : "#020" }, { "y" : 67, - "name" : "#021", - "drilldown" : "021" + "drilldown" : "021", + "name" : "#021" }, { "y" : 63, @@ -114,14 +129,14 @@ "drilldown" : "022" }, { - "y" : 91, "name" : "#023", - "drilldown" : "023" + "drilldown" : "023", + "y" : 91 }, { "y" : 70, - "drilldown" : "024", - "name" : "#024" + "name" : "#024", + "drilldown" : "024" }, { "name" : "#025", @@ -129,18 +144,18 @@ "y" : 55 }, { - "drilldown" : "026", "name" : "#026", + "drilldown" : "026", "y" : 70 }, { - "y" : 58, "drilldown" : "027", - "name" : "#027" + "name" : "#027", + "y" : 58 }, { - "name" : "#028", "drilldown" : "028", + "name" : "#028", "y" : 78 }, { @@ -149,58 +164,58 @@ "y" : 77 }, { - "name" : "#030", "drilldown" : "030", + "name" : "#030", "y" : 115 }, { - "y" : 87, "drilldown" : "031", - "name" : "#031" + "name" : "#031", + "y" : 87 }, { - "y" : 92, + "name" : "#032", "drilldown" : "032", - "name" : "#032" + "y" : 92 }, { "y" : 108, - "drilldown" : "033", - "name" : "#033" + "name" : "#033", + "drilldown" : "033" }, { - "y" : 62, + "name" : "#034", "drilldown" : "034", - "name" : "#034" + "y" : 62 }, { - "y" : 62, "drilldown" : "035", - "name" : "#035" + "name" : "#035", + "y" : 62 }, { - "name" : "#036", "drilldown" : "036", + "name" : "#036", "y" : 66 }, { "y" : 65, - "drilldown" : "037", - "name" : "#037" + "name" : "#037", + "drilldown" : "037" }, { - "drilldown" : "038", "name" : "#038", + "drilldown" : "038", "y" : 65 }, { - "drilldown" : "039", + "y" : 60, "name" : "#039", - "y" : 60 + "drilldown" : "039" }, { - "drilldown" : "040", "name" : "#040", + "drilldown" : "040", "y" : 71 }, { @@ -210,13 +225,13 @@ }, { "y" : 88, - "name" : "#042", - "drilldown" : "042" + "drilldown" : "042", + "name" : "#042" }, { - "y" : 66, "name" : "#043", - "drilldown" : "043" + "drilldown" : "043", + "y" : 66 }, { "y" : 82, @@ -224,24 +239,24 @@ "drilldown" : "044" }, { - "drilldown" : "045", + "y" : 94, "name" : "#045", - "y" : 94 + "drilldown" : "045" }, { + "y" : 85, "drilldown" : "046", - "name" : "#046", - "y" : 85 + "name" : "#046" }, { - "drilldown" : "047", "name" : "#047", + "drilldown" : "047", "y" : 82 }, { - "y" : 106, "name" : "#048", - "drilldown" : "048" + "drilldown" : "048", + "y" : 106 }, { "y" : 85, @@ -249,34 +264,34 @@ "name" : "#049" }, { - "y" : 96, + "name" : "#050", "drilldown" : "050", - "name" : "#050" + "y" : 96 }, { + "y" : 87, "drilldown" : "051", - "name" : "#051", - "y" : 87 + "name" : "#051" }, { - "name" : "#052", "drilldown" : "052", + "name" : "#052", "y" : 89 }, { - "y" : 99, + "drilldown" : "053", "name" : "#053", - "drilldown" : "053" + "y" : 99 }, { + "y" : 99, "name" : "#054", - "drilldown" : "054", - "y" : 99 + "drilldown" : "054" }, { - "name" : "#055", + "y" : 86, "drilldown" : "055", - "y" : 86 + "name" : "#055" }, { "y" : 93, @@ -289,14 +304,14 @@ "name" : "#057" }, { - "y" : 62, + "name" : "#058", "drilldown" : "058", - "name" : "#058" + "y" : 62 }, { - "y" : 82, + "name" : "#059", "drilldown" : "059", - "name" : "#059" + "y" : 82 }, { "y" : 78, @@ -305,23 +320,23 @@ }, { "y" : 79, - "drilldown" : "061", - "name" : "#061" + "name" : "#061", + "drilldown" : "061" }, { + "y" : 54, "drilldown" : "062", - "name" : "#062", - "y" : 54 + "name" : "#062" }, { - "y" : 87, + "drilldown" : "063", "name" : "#063", - "drilldown" : "063" + "y" : 87 }, { + "y" : 76, "name" : "#064", - "drilldown" : "064", - "y" : 76 + "drilldown" : "064" }, { "y" : 71, @@ -329,29 +344,41 @@ "name" : "#065" }, { - "y" : 81, "name" : "#066", - "drilldown" : "066" + "drilldown" : "066", + "y" : 81 }, { + "y" : 86, "drilldown" : "067", - "name" : "#067", - "y" : 86 + "name" : "#067" }, { + "y" : 29, "drilldown" : "068", - "name" : "#068", - "y" : 28 + "name" : "#068" } ], "colorByPoint" : "true" } ], + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "chart" : { + "type" : "column" + }, + "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>" + }, "drilldown" : { "series" : [ { "id" : "001", - "name" : "001", "data" : [ [ "Perl", @@ -365,11 +392,11 @@ "Blog", 11 ] - ] + ], + "name" : "001" }, { "name" : "002", - "id" : "002", "data" : [ [ "Perl", @@ -383,9 +410,12 @@ "Blog", 10 ] - ] + ], + "id" : "002" }, { + "id" : "003", + "name" : "003", "data" : [ [ "Perl", @@ -399,11 +429,10 @@ "Blog", 9 ] - ], - "name" : "003", - "id" : "003" + ] }, { + "name" : "004", "data" : [ [ "Perl", @@ -418,8 +447,7 @@ 10 ] ], - "id" : "004", - "name" : "004" + "id" : "004" }, { "data" : [ @@ -436,11 +464,10 @@ 12 ] ], - "id" : "005", - "name" : "005" + "name" : "005", + "id" : "005" }, { - "id" : "006", "name" : "006", "data" : [ [ @@ -455,11 +482,11 @@ "Blog", 7 ] - ] + ], + "id" : "006" }, { "id" : "007", - "name" : "007", "data" : [ [ "Perl", @@ -473,9 +500,11 @@ "Blog", 10 ] |
