diff options
24 files changed, 3024 insertions, 2938 deletions
diff --git a/challenge-285/cheok-yin-fung/perl/ch-1.pl b/challenge-285/cheok-yin-fung/perl/ch-1.pl new file mode 100755 index 0000000000..1e6feee58d --- /dev/null +++ b/challenge-285/cheok-yin-fung/perl/ch-1.pl @@ -0,0 +1,23 @@ +# The Weekly Challenge 285 +# Task 1 No Connection +use v5.30; +use warnings; +use List::Util qw/uniqstr/; + +sub nc { + my @routes = $_[0]->@*; + my %dest; + my @places; + for my $route (@routes) { + $dest{$route->[0]} = $route->[1]; + push @places, $route->[0], $route->[1]; + @places = uniqstr @places; + } + for my $p (@places) { + return $p if !defined($dest{$p}) + } +} + +use Test::More tests=>2; +ok nc([["B","C"],["D","B"],["C","A"]]) eq "A"; +ok nc([["A","Z"]]) eq "Z"; diff --git a/challenge-285/cheok-yin-fung/perl/ch-2.pl b/challenge-285/cheok-yin-fung/perl/ch-2.pl new file mode 100755 index 0000000000..600e39ca51 --- /dev/null +++ b/challenge-285/cheok-yin-fung/perl/ch-2.pl @@ -0,0 +1,48 @@ +# The Weekly Challenge 285 +# Task 2 Making Change +use v5.30; +use warnings; +use List::Util qw/uniqstr/; + +my @arr; +$arr[0] = [""]; +$arr[1] = ["1"]; + + +sub mc { + my $amt = $_[0]; + return scalar $arr[$amt]->@* if defined $arr[$amt]; + for (2..$amt-1) {mc($_);} + if ($amt >= 50) { + $arr[$amt] = [uniqstr (map {add_amt($arr[$amt-$_], $_)->@*} (1,5,10,25,50))]; + } elsif ($amt >= 25) { + $arr[$amt] = [uniqstr (map {add_amt($arr[$amt-$_], $_)->@*} (1,5,10,25))]; + } elsif ($amt >= 10) { + $arr[$amt] = [uniqstr (map {add_amt($arr[$amt-$_], $_)->@*} (1,5,10))]; + } elsif ($amt >= 5) { + $arr[$amt] = [uniqstr ( map {add_amt($arr[$amt-$_], $_)->@*} (1,5))]; + } elsif ($amt > 0) { + $arr[$amt] = [uniqstr (add_amt($arr[$amt-1], 1)->@*) ]; + } + # say join "\n", $arr[$amt]->@*; + return scalar $arr[$amt]->@*; +} + +sub add_amt { + my @ways = $_[0]->@*; + my @nways; + my $c = $_[1]; + foreach my $way (@ways) { + my @coins = split ",", $way; + push @coins, $c; + @coins = sort {$a<=>$b} @coins; + my $nway = join ",", @coins; + push @nways, $nway; + } + return [@nways]; +} + +use Test::More tests=>3; +ok mc(9) == 2; +ok mc(15) == 6; +ok mc(100) == 292; diff --git a/stats/pwc-current.json b/stats/pwc-current.json index f20c84f8c2..0df4ee44f3 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,146 +1,22 @@ { - "series" : [ - { - "data" : [ - { - "y" : 3, - "name" : "Ali Moradi", - "drilldown" : "Ali Moradi" - }, - { - "name" : "Arne Sommer", - "y" : 3, - "drilldown" : "Arne Sommer" - }, - { - "y" : 2, - "name" : "Dave Jacoby", - "drilldown" : "Dave Jacoby" - }, - { - "name" : "David Ferrone", - "y" : 3, - "drilldown" : "David Ferrone" - }, - { - "drilldown" : "E. Choroba", - "y" : 2, - "name" : "E. Choroba" - }, - { - "drilldown" : "Feng Chang", - "y" : 2, - "name" : "Feng Chang" - }, - { - "drilldown" : "Jorg Sommrey", - "y" : 3, - "name" : "Jorg Sommrey" - }, - { - "drilldown" : "Kjetil Skotheim", - "name" : "Kjetil Skotheim", - "y" : 2 - }, - { - "y" : 6, - "name" : "Laurent Rosenfeld", - "drilldown" : "Laurent Rosenfeld" - }, - { - "drilldown" : "Mark Anderson", - "name" : "Mark Anderson", - "y" : 2 - }, - { - "name" : "Matthew Neleigh", - "y" : 2, - "drilldown" : "Matthew Neleigh" - }, - { - "drilldown" : "Matthias Muth", - "y" : 3, - "name" : "Matthias Muth" - }, - { - "drilldown" : "Nelo Tovar", - "name" : "Nelo Tovar", - "y" : 2 - }, - { - "y" : 5, - "name" : "Packy Anderson", - "drilldown" : "Packy Anderson" - }, - { - "name" : "Paulo Custodio", - "y" : 2, - "drilldown" : "Paulo Custodio" - }, - { - "drilldown" : "Peter Campbell Smith", - "y" : 3, - "name" : "Peter Campbell Smith" - }, - { - "y" : 2, - "name" : "Peter Meszaros", - "drilldown" : "Peter Meszaros" - }, - { - "drilldown" : "Reinier Maliepaard", - "y" : 2, - "name" : "Reinier Maliepaard" - }, - { - "drilldown" : "Robbie Hatley", - "y" : 3, - "name" : "Robbie Hatley" - }, - { - "drilldown" : "Robert Ransbottom", - "name" : "Robert Ransbottom", - "y" : 2 - }, - { - "name" : "Roger Bell_West", - "y" : 4, - "drilldown" : "Roger Bell_West" - }, - { - "drilldown" : "Thomas Kohler", - "name" : "Thomas Kohler", - "y" : 4 - }, - { - "drilldown" : "Tim King", - "name" : "Tim King", - "y" : 2 - }, - { - "drilldown" : "Torgny Lyon", - "name" : "Torgny Lyon", - "y" : 3 - }, - { - "name" : "Ulrich Rieke", - "y" : 4, - "drilldown" : "Ulrich Rieke" - }, - { - "y" : 3, - "name" : "W. Luis Mochan", - "drilldown" : "W. Luis Mochan" - } - ], - "name" : "The Weekly Challenge - 285", - "colorByPoint" : 1 + "plotOptions" : { + "series" : { + "borderWidth" : 0, + "dataLabels" : { + "enabled" : 1, + "format" : "{point.y}" + } } - ], + }, + "xAxis" : { + "type" : "category" + }, + "legend" : { + "enabled" : 0 + }, "drilldown" : { "series" : [ { - "name" : "Ali Moradi", "data" : [ [ "Perl", @@ -151,10 +27,12 @@ 1 ] ], + "name" : "Ali Moradi", "id" : "Ali Moradi" }, { "id" : "Arne Sommer", + "name" : "Arne Sommer", "data" : [ [ "Raku", @@ -164,20 +42,31 @@ "Blog", 1 ] + ] + }, + { + "data" : [ + [ + "Perl", + 2 + ] ], - "name" : "Arne Sommer" + "name" : "Cheok-Yin Fung", + "id" : "Cheok-Yin Fung" }, { - "id" : "Dave Jacoby", "data" : [ [ "Perl", 2 ] ], + "id" : "Dave Jacoby", "name" : "Dave Jacoby" }, { + "id" : "David Ferrone", + "name" : "David Ferrone", "data" : [ [ "Perl", @@ -187,13 +76,11 @@ "Blog", 1 ] - ], - "id" : "David Ferrone", - "name" : "David Ferrone" + ] }, { - "name" : "E. Choroba", "id" : "E. Choroba", + "name" : "E. Choroba", "data" : [ [ "Perl", @@ -202,18 +89,16 @@ ] }, { + "id" : "Feng Chang", "name" : "Feng Chang", "data" : [ [ "Raku", 2 ] - ], - "id" : "Feng Chang" + ] }, { - "name" : "Jorg Sommrey", - "id" : "Jorg Sommrey", "data" : [ [ "Perl", @@ -223,17 +108,19 @@ "Blog", 1 ] - ] + ], + "id" : "Jorg Sommrey", + "name" : "Jorg Sommrey" }, { - "id" : "Kjetil Skotheim", "data" : [ [ "Perl", 2 ] ], - "name" : "Kjetil Skotheim" + "name" : "Kjetil Skotheim", + "id" : "Kjetil Skotheim" }, { "name" : "Laurent Rosenfeld", @@ -254,26 +141,28 @@ ] }, { + "id" : "Mark Anderson", + "name" : "Mark Anderson", "data" : [ [ "Raku", 2 ] - ], - "id" : "Mark Anderson", - "name" : "Mark Anderson" + ] }, { + "name" : "Matthew Neleigh", + "id" : "Matthew Neleigh", "data" : [ [ "Perl", 2 ] - ], - "id" : "Matthew Neleigh", - "name" : "Matthew Neleigh" + ] }, { + "id" : "Matthias Muth", + "name" : "Matthias Muth", "data" : [ [ "Perl", @@ -283,19 +172,17 @@ "Blog", 1 ] - ], - "id" : "Matthias Muth", - "name" : "Matthias Muth" + ] }, { - "name" : "Nelo Tovar", "data" : [ [ "Perl", 2 ] ], - "id" : "Nelo Tovar" + "id" : "Nelo Tovar", + "name" : "Nelo Tovar" }, { "data" : [ @@ -316,16 +203,18 @@ "name" : "Packy Anderson" }, { - "id" : "Paulo Custodio", "data" : [ [ "Perl", 2 ] ], + "id" : "Paulo Custodio", "name" : "Paulo Custodio" }, { + "name" : "Peter Campbell Smith", + "id" : "Peter Campbell Smith", "data" : [ [ "Perl", @@ -335,13 +224,11 @@ "Blog", 1 ] - ], - "id" : "Peter Campbell Smith", - "name" : "Peter Campbell Smith" + ] }, { - "name" : "Peter Meszaros", "id" : "Peter Meszaros", + "name" : "Peter Meszaros", "data" : [ [ "Perl", @@ -350,8 +237,6 @@ ] }, { - "name" : "Reinier Maliepaard", - "id" : "Reinier Maliepaard", "data" : [ [ "Perl", @@ -361,10 +246,13 @@ "Blog", 1 ] - ] + ], + "id" : "Reinier Maliepaard", + "name" : "Reinier Maliepaard" }, { "name" : "Robbie Hatley", + "id" : "Robbie Hatley", "data" : [ [ "Perl", @@ -374,20 +262,20 @@ "Blog", 1 ] - ], - "id" : "Robbie Hatley" + ] }, { - "id" : "Robert Ransbottom", "data" : [ [ "Raku", 2 ] ], - "name" : "Robert Ransbottom" + "name" : "Robert Ransbottom", + "id" : "Robert Ransbottom" }, { + "id" : "Roger Bell_West", "name" : "Roger Bell_West", "data" : [ [ @@ -398,8 +286,7 @@ "Raku", 2 ] - ], - "id" : "Roger Bell_West" + ] }, { "data" : [ @@ -416,14 +303,14 @@ "name" : "Thomas Kohler" }, { + "name" : "Tim King", + "id" : "Tim King", "data" : [ [ "Perl", 2 ] - ], - "id" : "Tim King", - "name" : "Tim King" + ] }, { "name" : "Torgny Lyon", @@ -450,12 +337,12 @@ 2 ] ], - "id" : "Ulrich Rieke", - "name" : "Ulrich Rieke" + "name" : "Ulrich Rieke", + "id" : "Ulrich Rieke" }, { - "name" : "W. Luis Mochan", "id" : "W. Luis Mochan", + "name" : "W. Luis Mochan", "data" : [ [ "Perl", @@ -469,24 +356,6 @@ } ] }, - "title" : { - "text" : "The Weekly Challenge - 285" - }, - "plotOptions" : { - "series" : { - "borderWidth" : 0, - "dataLabels" : { - "enabled" : 1, - "format" : "{point.y}" - } - } - }, - "legend" : { - "enabled" : 0 - }, - "xAxis" : { - "type" : "category" - }, "chart" : { "type" : "column" }, @@ -495,12 +364,158 @@ "text" : "Total Solutions" } }, + "subtitle" : { + "text" : "[Champions: 27] Last updated at 2024-09-08 10:45:10 GMT" + }, + "title" : { + "text" : "The Weekly Challenge - 285" + }, "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, + "pointFormat" : "<span style='color:{point.color}'>{point.name}</span>: <b>{point.y:f}</b><br/>" }, - "subtitle" : { - "text" : "[Champions: 26] Last updated at 2024-09-07 19:17:23 GMT" - } + "series" : [ + { + "name" : "The Weekly Challenge - 285", + "colorByPoint" : 1, + "data" : [ + { + "y" : 3, + "drilldown" : "Ali Moradi", + "name" : "Ali Moradi" + }, + { + "name" : "Arne Sommer", + "drilldown" : "Arne Sommer", + "y" : 3 + }, + { + "name" : "Cheok-Yin Fung", + "drilldown" : "Cheok-Yin Fung", + "y" : 2 + }, + { + "drilldown" : "Dave Jacoby", + "name" : "Dave Jacoby", + "y" : 2 + }, + { + "y" : 3, + "name" : "David Ferrone", + "drilldown" : "David Ferrone" + }, + { + "drilldown" : "E. Choroba", + "name" : "E. Choroba", + "y" : 2 + }, + { + "y" : 2, + "drilldown" : "Feng Chang", + "name" : "Feng Chang" + }, + { + "y" : 3, + "name" : "Jorg Sommrey", + "drilldown" : "Jorg Sommrey" + }, + { + "name" : "Kjetil Skotheim", + "drilldown" : "Kjetil Skotheim", + "y" : 2 + }, + { + "name" : "Laurent Rosenfeld", + "drilldown" : "Laurent Rosenfeld", + "y" : 6 + }, + { + "drilldown" : "Mark Anderson", + "name" : "Mark Anderson", + "y" : 2 + }, + { + "drilldown" : "Matthew Neleigh", + "name" : "Matthew Neleigh", + "y" : 2 + }, + { + "y" : 3, + "drilldown" : "Matthias Muth", + "name" : "Matthias Muth" + }, + { + "name" : "Nelo Tovar", + "drilldown" : "Nelo Tovar", + "y" : 2 + }, + { + "name" : "Packy Anderson", + "drilldown" : "Packy Anderson", + "y" : 5 + }, + { + "y" : 2, + "drilldown" : "Paulo Custodio", + "name" : "Paulo Custodio" + }, + { + "drilldown" : "Peter Campbell Smith", + "name" : "Peter Campbell Smith", + "y" : 3 + }, + { + "drilldown" : "Peter Meszaros", + "name" : "Peter Meszaros", + "y" : 2 + }, + { + "y" : 2, + "drilldown" : "Reinier Maliepaard", + "name" : "Reinier Maliepaard" + }, + { + "name" : "Robbie Hatley", + "drilldown" : "Robbie Hatley", + "y" : 3 + }, + { + "y" : 2, + "drilldown" : "Robert Ransbottom", + "name" : "Robert Ransbottom" + }, + { + "name" : "Roger Bell_West", + "drilldown" : "Roger Bell_West", + "y" : 4 + }, + { + "y" : 4, + "name" : "Thomas Kohler", + "drilldown" : "Thomas Kohler" + }, + { + "y" : 2, + "drilldown" : "Tim King", + "name" : "Tim King" + }, + { + "y" : 3, + "drilldown" : "Torgny Lyon", + "name" : "Torgny Lyon" + }, + { + "y" : 4, + "name" : "Ulrich Rieke", + "drilldown" : "Ulrich Rieke" + }, + { + "y" : 3, + "drilldown" : "W. Luis Mochan", + "name" : "W. Luis Mochan" + } + ] + } + ] } diff --git a/stats/pwc-language-breakdown-2019.json b/stats/pwc-language-breakdown-2019.json index 95b138c830..5a4ea1d1a0 100644 --- a/stats/pwc-language-breakdown-2019.json +++ b/stats/pwc-language-breakdown-2019.json @@ -1,11 +1,227 @@ { + "series" : [ + { + "name" : "The Weekly Challenge Languages", + "data" : [ + { + "drilldown" : "041", + "name" : "041", + "y" : 80 + }, + { + "drilldown" : "040", + "name" : "040", + "y" : 77 + }, + { + "y" : 68, + "name" : "039", + "drilldown" : "039" + }, + { + "name" : "038", + "drilldown" : "038", + "y" : 74 + }, + { + "drilldown" : "037", + "name" : "037", + "y" : 70 + }, + { + "y" : 70, + "drilldown" : "036", + "name" : "036" + }, + { + "y" : 68, + "name" : "035", + "drilldown" : "035" + }, + { + "y" : 70, + "drilldown" : "034", + "name" : "034" + }, + { + "y" : 113, + "name" : "033", + "drilldown" : "033" + }, + { + "y" : 97, + "name" : "032", + "drilldown" : "032" + }, + { + "name" : "031", + "drilldown" : "031", + "y" : 93 + }, + { + "y" : 120, + "drilldown" : "030", + "name" : "030" + }, + { + "y" : 83, + "name" : "029", + "drilldown" : "029" + }, + { + "drilldown" : "028", + "name" : "028", + "y" : 82 + }, + { + "y" : 64, + "drilldown" : "027", + "name" : "027" + }, + { + "y" : 75, + "name" : "026", + "drilldown" : "026" + }, + { + "name" : "025", + "drilldown" : "025", + "y" : 62 + }, + { + "name" : "024", + "drilldown" : "024", + "y" : 77 + }, + { + "name" : "023", + "drilldown" : "023", + "y" : 88 + }, + { + "drilldown" : "022", + "name" : "022", + "y" : 72 + }, + { + "name" : "021", + "drilldown" : "021", + "y" : 72 + }, + { + "name" : "020", + "drilldown" : "020", + "y" : 100 + }, + { + "name" : "019", + "drilldown" : "019", + "y" : 101 + }, + { + "drilldown" : "018", + "name" : "018", + "y" : 82 + }, + { + "y" : 83, + "name" : "017", + "drilldown" : "017" + }, + { + "y" : 75, + "drilldown" : "016", + "name" : "016" + }, + { + "y" : 95, + "drilldown" : "015", + "name" : "015" + }, + { + "drilldown" : "014", + "name" : "014", + "y" : 98 + }, + { + "y" : 85, + "drilldown" : "013", + "name" : "013" + }, + { + "y" : 90, + "name" : "012", + "drilldown" : "012" + }, + { + "name" : "011", + "drilldown" : "011", + "y" : 86 + }, + { + "name" : "010", + "drilldown" : "010", + "y" : 69 + }, + { + "y" : 79, + "name" : "009", + "drilldown" : "009" + }, + { + "drilldown" : "008", + "name" : "008", + "y" : 82 + }, + { + "y" : 71, + "drilldown" : "007", + "name" : "007" + }, + { + "name" : "006", + "drilldown" : "006", + "y" : 63 + }, + { + "y" : 82, + "drilldown" : "005", + "name" : "005" + }, + { + "y" : 106, + "name" : "004", + "drilldown" : "004" + }, + { + "name" : "003", + "drilldown" : "003", + "y" : 91 + }, + { + "drilldown" : "002", + "name" : "002", + "y" : 133 + }, + { + "drilldown" : "001", + "name" : "001", + "y" : 165 + } + ], + "colorByPoint" : "true" + } + ], "tooltip" : { "pointFormat" : "<span style=\"color:{point.color}\">Challenge {point.name}</span>: <b>{point.y:f}</b><br/>", - "headerFormat" : "<span style=\"font-size:11px\"></span>", - "followPointer" : "true" + "followPointer" : "true", + "headerFormat" : "<span style=\"font-size:11px\"></span>" }, "subtitle" : { - "text" : "Click the columns to drilldown the language breakdown. Last updated at 2024-09-07 19:17:23 GMT" + "text" : "Click the columns to drilldown the language breakdown. Last updated at 2024-09-08 10:45:10 GMT" + }, + "title" : { + "text" : "The Weekly Challenge Language" }, "yAxis" : { "title" : { @@ -15,27 +231,11 @@ "chart" : { "type" : "column" }, - "xAxis" : { - "type" : "category" - }, - "legend" : { - "enabled" : "false" - }, - "plotOptions" : { - "series" : { - "borderWidth" : 0, - "dataLabels" : { - "enabled" : 1, - "format" : "{point.y}" - } - } - }, - "title" : { - "text" : "The Weekly Challenge Language" - }, "drilldown" : { "series" : [ { + "id" : "041", + "name" : "041", "data" : [ [ "Perl", @@ -49,11 +249,10 @@ "Blog", 9 ] - ], - "id" : "041", - "name" : "041" + ] }, { + "name" : "040", "id" : "040", "data" : [ [ @@ -68,11 +267,9 @@ "Blog", 10 ] - ], - "name" : "040" + ] }, { - "id" : "039", "data" : [ [ "Perl", @@ -87,7 +284,8 @@ 12 ] ], - "name" : "039" + "name" : "039", + "id" : "039" }, { "data" : [ @@ -109,6 +307,7 @@ |
