From 4627610b81d312e5ff3ea2145d10c5dcd537fc93 Mon Sep 17 00:00:00 2001 From: Mohammad Sajid Anwar Date: Mon, 19 Aug 2024 14:33:23 +0100 Subject: - Added solutions by Ulrich Rieke. --- challenge-283/ulrich-rieke/cpp/ch-1.cpp | 33 ++ challenge-283/ulrich-rieke/cpp/ch-2.cpp | 35 ++ challenge-283/ulrich-rieke/haskell/ch-1.hs | 12 + challenge-283/ulrich-rieke/haskell/ch-2.hs | 19 + challenge-283/ulrich-rieke/perl/ch-1.pl | 13 + challenge-283/ulrich-rieke/perl/ch-2.pl | 18 + challenge-283/ulrich-rieke/raku/ch-1.raku | 8 + challenge-283/ulrich-rieke/raku/ch-2.raku | 12 + challenge-283/ulrich-rieke/rust/ch-1.rs | 21 + challenge-283/ulrich-rieke/rust/ch-2.rs | 16 + stats/pwc-current.json | 145 +++--- stats/pwc-language-breakdown-2019.json | 320 ++++++------ stats/pwc-language-breakdown-2020.json | 384 +++++++-------- stats/pwc-language-breakdown-2021.json | 762 ++++++++++++++--------------- stats/pwc-language-breakdown-2022.json | 398 +++++++-------- stats/pwc-language-breakdown-2023.json | 742 ++++++++++++++-------------- stats/pwc-language-breakdown-2024.json | 526 ++++++++++---------- stats/pwc-language-breakdown-summary.json | 68 +-- stats/pwc-leaders.json | 720 +++++++++++++-------------- stats/pwc-summary-1-30.json | 100 ++-- stats/pwc-summary-121-150.json | 44 +- stats/pwc-summary-151-180.json | 92 ++-- stats/pwc-summary-181-210.json | 56 +-- stats/pwc-summary-211-240.json | 44 +- stats/pwc-summary-241-270.json | 118 ++--- stats/pwc-summary-271-300.json | 110 ++--- stats/pwc-summary-301-330.json | 72 +-- stats/pwc-summary-31-60.json | 118 ++--- stats/pwc-summary-61-90.json | 96 ++-- stats/pwc-summary-91-120.json | 30 +- stats/pwc-summary.json | 36 +- stats/pwc-yearly-language-summary.json | 138 +++--- 32 files changed, 2756 insertions(+), 2550 deletions(-) create mode 100755 challenge-283/ulrich-rieke/cpp/ch-1.cpp create mode 100755 challenge-283/ulrich-rieke/cpp/ch-2.cpp create mode 100755 challenge-283/ulrich-rieke/haskell/ch-1.hs create mode 100755 challenge-283/ulrich-rieke/haskell/ch-2.hs create mode 100755 challenge-283/ulrich-rieke/perl/ch-1.pl create mode 100755 challenge-283/ulrich-rieke/perl/ch-2.pl create mode 100755 challenge-283/ulrich-rieke/raku/ch-1.raku create mode 100755 challenge-283/ulrich-rieke/raku/ch-2.raku create mode 100755 challenge-283/ulrich-rieke/rust/ch-1.rs create mode 100755 challenge-283/ulrich-rieke/rust/ch-2.rs diff --git a/challenge-283/ulrich-rieke/cpp/ch-1.cpp b/challenge-283/ulrich-rieke/cpp/ch-1.cpp new file mode 100755 index 0000000000..908539ecf9 --- /dev/null +++ b/challenge-283/ulrich-rieke/cpp/ch-1.cpp @@ -0,0 +1,33 @@ +#include +#include +#include +#include +#include + +std::vector split( std::string text , const char delimiter ) { + std::stringstream instr { text } ; + std::string word ; + std::vector tokens ; + while ( std::getline( instr , word , delimiter )) + tokens.push_back( word ) ; + return tokens ; +} + +int main( ) { + std::cout << "Enter some integers several times , one only once!\n" ; + std::string line ; + std::getline( std::cin , line ) ; + auto tokens { split( line, ' ' ) } ; + std::vector numbers ; + for ( auto s : tokens ) + numbers.push_back( std::stoi( s ) ) ; + std::map frequencies ; + for ( int i : numbers ) + frequencies[i]++ ; + for ( auto it = frequencies.begin( ) ; it != frequencies.end( ) ; ++it ) { + if ( it->second == 1 ) { + std::cout << it->first << '\n' ; + } + } + return 0 ; +} diff --git a/challenge-283/ulrich-rieke/cpp/ch-2.cpp b/challenge-283/ulrich-rieke/cpp/ch-2.cpp new file mode 100755 index 0000000000..a53ddde486 --- /dev/null +++ b/challenge-283/ulrich-rieke/cpp/ch-2.cpp @@ -0,0 +1,35 @@ +#include +#include +#include +#include +#include +#include + +std::vector split( std::string text , const char delimiter ) { + std::stringstream instr { text } ; + std::vector allTokens ; + std::string word ; + while ( std::getline( instr, word , delimiter ) ) { + allTokens.push_back( word ) ; + } + return allTokens ; +} + +int main( ) { + std::cout << "Enter some positive integers, separated by blanks!\n" ; + std::string line ; + std::getline( std::cin , line ) ; + std::vector tokens { split( line, ' ' ) } ; + std::vector numbers ; + for ( auto s : tokens ) + numbers.push_back( std::stoi( s ) ) ; + int len = numbers.size( ) ; + std::vector indices( len ) ; + std::iota( indices.begin( ) , indices.end( ) , 0 ) ; + bool result = std::all_of( indices.begin( ) , indices.end( ) , + [&numbers]( int i ) { return std::count( numbers.begin( ) , + numbers.end( ) , i ) == numbers[ i ] ; } ) ; + std::cout << std::boolalpha << result << '\n' ; + return 0 ; +} + diff --git a/challenge-283/ulrich-rieke/haskell/ch-1.hs b/challenge-283/ulrich-rieke/haskell/ch-1.hs new file mode 100755 index 0000000000..988d9412a4 --- /dev/null +++ b/challenge-283/ulrich-rieke/haskell/ch-1.hs @@ -0,0 +1,12 @@ +module Challenge283 + where +import Data.List ( sort , group ) + +solution :: [Int] -> Int +solution = head . head . filter ( (== 1 ) . length ) . group . sort + +main :: IO ( ) +main = do + putStrLn "Enter some integers several times , one only once!" + numberline <- getLine + print $ solution $ map read $ words numberline diff --git a/challenge-283/ulrich-rieke/haskell/ch-2.hs b/challenge-283/ulrich-rieke/haskell/ch-2.hs new file mode 100755 index 0000000000..ba19d6e631 --- /dev/null +++ b/challenge-283/ulrich-rieke/haskell/ch-2.hs @@ -0,0 +1,19 @@ +module Challenge283_2 + where +import Data.List ( (!!) ) + +count :: Eq a => a -> [a] -> Int +count _ [] = 0 +count d (x:xs) + |d == x = 1 + count d xs + |otherwise = count d xs + +solution :: [Int] -> Bool +solution numbers = all (\(index , number) -> count index numbers == + numbers !! index ) $ zip [0 , 1 ..] numbers + +main :: IO ( ) +main = do + putStrLn "Enter some numbers , separated by blanks!" ; + numberline <- getLine + print $ solution $ map read $ words numberline diff --git a/challenge-283/ulrich-rieke/perl/ch-1.pl b/challenge-283/ulrich-rieke/perl/ch-1.pl new file mode 100755 index 0000000000..3cf76603df --- /dev/null +++ b/challenge-283/ulrich-rieke/perl/ch-1.pl @@ -0,0 +1,13 @@ +#!/usr/bin/perl ; +use strict ; +use warnings ; +use feature 'say' ; + +say "Enter some numbers several times, only one number once!" ; +my $line = ; +chomp $line ; +my @numbers = split( /\s+/ , $line ) ; +my %frequencies ; +map { $frequencies{$_}++ } @numbers ; +my @selected = grep { $frequencies{$_} == 1 } @numbers ; +say $selected[0] ; diff --git a/challenge-283/ulrich-rieke/perl/ch-2.pl b/challenge-283/ulrich-rieke/perl/ch-2.pl new file mode 100755 index 0000000000..87f600eb74 --- /dev/null +++ b/challenge-283/ulrich-rieke/perl/ch-2.pl @@ -0,0 +1,18 @@ +#!/usr/bin/perl ; +use strict ; +use warnings ; +use feature 'say' ; + +say "Enter some positive integers, separated by blanks!" ; +my $line = ; +chomp $line ; +my @numbers = split( /\s+/ , $line ) ; +my $len = scalar( @numbers ) - 1 ; +#assume result to be true unless proven to be false +my $result = "true" ; +for my $index (0..$len ) { + if ( scalar( grep { $_ == $index } @numbers ) != $numbers[ $index ] ) { + $result = "false" ; + } +} +say $result ; diff --git a/challenge-283/ulrich-rieke/raku/ch-1.raku b/challenge-283/ulrich-rieke/raku/ch-1.raku new file mode 100755 index 0000000000..c1d1725c61 --- /dev/null +++ b/challenge-283/ulrich-rieke/raku/ch-1.raku @@ -0,0 +1,8 @@ +use v6 ; + +say "Enter several numbers more than once , only one once!" ; +my $line = $*IN.get ; +my @numbers = $line.words.map( {.Int} ) ; +my %frequencies ; +@numbers.map( {%frequencies{$_}++} ) ; +say @numbers.grep( {%frequencies{$_} == 1})[0] ; diff --git a/challenge-283/ulrich-rieke/raku/ch-2.raku b/challenge-283/ulrich-rieke/raku/ch-2.raku new file mode 100755 index 0000000000..f95e3a274b --- /dev/null +++ b/challenge-283/ulrich-rieke/raku/ch-2.raku @@ -0,0 +1,12 @@ +use v6 ; + +say "Enter some positive integers, separated by blanks!" ; +my $line = $*IN.get ; +my @numbers = $line.words.map( {.Int} ) ; +my $result = True ; +for (0..@numbers.elems - 1) -> $i { + if (( @numbers.grep( {$_ == $i} ).elems) != @numbers[ $i ] ) { + $result = False ; + } +} +say $result ; diff --git a/challenge-283/ulrich-rieke/rust/ch-1.rs b/challenge-283/ulrich-rieke/rust/ch-1.rs new file mode 100755 index 0000000000..c643a5e44d --- /dev/null +++ b/challenge-283/ulrich-rieke/rust/ch-1.rs @@ -0,0 +1,21 @@ +use std::io ; +use std::collections::HashMap ; + +fn main() { + println!("Enter some integers several times , one only once!"); + let mut inline : String = String::new( ) ; + io::stdin( ).read_line( &mut inline ).unwrap( ) ; + let entered_line : &str = inline.as_str( ).trim( ) ; + let numbers : Vec = entered_line.split_whitespace( ).map( | s | + s.parse::( ).unwrap( ) ).collect( ) ; + let mut frequencies : HashMap<_,_> = HashMap::new( ) ; + numbers.into_iter( ).for_each( | n | { + frequencies.entry( n ). + and_modify( | e | *e += 1 ).or_insert( 1 ) ; + } ) ; + for ( k , v ) in &frequencies { + if *v == 1 { + println!("{}" , k ) ; + } + } +} diff --git a/challenge-283/ulrich-rieke/rust/ch-2.rs b/challenge-283/ulrich-rieke/rust/ch-2.rs new file mode 100755 index 0000000000..770496ffc4 --- /dev/null +++ b/challenge-283/ulrich-rieke/rust/ch-2.rs @@ -0,0 +1,16 @@ +use std::io ; + +fn main() { + println!("Enter some positive integers separated by blanks!"); + let mut inline : String = String::new( ) ; + io::stdin( ).read_line( &mut inline ).unwrap( ) ; + let entered_line : &str = inline.as_str( ).trim( ) ; + let numbers : Vec = entered_line.split_whitespace( ).map( | s | + s.parse::( ).unwrap( ) ).collect( ) ; + let result : bool = (0..numbers.len( )).all( | i | { + let number : u32 = numbers[ i ] ; + numbers.iter( ).filter( | &d | *d == (i as u32) ).count( ) == + number as usize + }) ; + println!("{}" , result ) ; +} diff --git a/stats/pwc-current.json b/stats/pwc-current.json index e50dbc52a6..9e875e2096 100644 --- a/stats/pwc-current.json +++ b/stats/pwc-current.json @@ -1,30 +1,4 @@ { - "subtitle" : { - "text" : "[Champions: 9] Last updated at 2024-08-19 12:34:56 GMT" - }, - "title" : { - "text" : "The Weekly Challenge - 283" - }, - "chart" : { - "type" : "column" - }, - "plotOptions" : { - "series" : { - "dataLabels" : { - "enabled" : 1, - "format" : "{point.y}" - }, - "borderWidth" : 0 - } - }, - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } - }, - "legend" : { - "enabled" : 0 - }, "drilldown" : { "series" : [ { @@ -42,12 +16,12 @@ 1 ] ], - "name" : "Ali Moradi", - "id" : "Ali Moradi" + "id" : "Ali Moradi", + "name" : "Ali Moradi" }, { - "id" : "E. Choroba", "name" : "E. Choroba", + "id" : "E. Choroba", "data" : [ [ "Perl", @@ -56,34 +30,34 @@ ] }, { - "id" : "Feng Chang", - "name" : "Feng Chang", "data" : [ [ "Raku", 2 ] - ] + ], + "id" : "Feng Chang", + "name" : "Feng Chang" }, { "id" : "Kjetil Skotheim", - "name" : "Kjetil Skotheim", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "Kjetil Skotheim" }, { - "name" : "Mark Anderson", "data" : [ [ "Raku", 2 ] ], - "id" : "Mark Anderson" + "id" : "Mark Anderson", + "name" : "Mark Anderson" }, { "data" : [ @@ -92,21 +66,22 @@ 2 ] ], - "name" : "Niels van Dijke", - "id" : "Niels van Dijke" + "id" : "Niels van Dijke", + "name" : "Niels van Dijke" }, { "id" : "Paulo Custodio", - "name" : "Paulo Custodio", "data" : [ [ "Perl", 2 ] - ] + ], + "name" : "Paulo Custodio" }, { "name" : "Peter Campbell Smith", + "id" : "Peter Campbell Smith", "data" : [ [ "Perl", @@ -116,39 +91,80 @@ "Blog", 1 ] - ], - "id" : "Peter Campbell Smith" + ] }, { - "id" : "Peter Meszaros", "data" : [ [ "Perl", 2 ] ], + "id" : "Peter Meszaros", "name" : "Peter Meszaros" + }, + { + "data" : [ + [ + "Perl", + 2 + ], + [ + "Raku", + 2 + ] + ], + "id" : "Ulrich Rieke", + "name" : "Ulrich Rieke" } ] }, + "subtitle" : { + "text" : "[Champions: 10] Last updated at 2024-08-19 13:33:03 GMT" + }, + "xAxis" : { + "type" : "category" + }, + "title" : { + "text" : "The Weekly Challenge - 283" + }, + "chart" : { + "type" : "column" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "legend" : { + "enabled" : 0 + }, + "plotOptions" : { + "series" : { + "borderWidth" : 0, + "dataLabels" : { + "format" : "{point.y}", + "enabled" : 1 + } + } + }, "series" : [ { - "name" : "The Weekly Challenge - 283", "data" : [ { - "name" : "Ali Moradi", "drilldown" : "Ali Moradi", + "name" : "Ali Moradi", "y" : 5 }, { - "name" : "E. Choroba", + "y" : 2, "drilldown" : "E. Choroba", - "y" : 2 + "name" : "E. Choroba" }, { - "name" : "Feng Chang", + "y" : 2, "drilldown" : "Feng Chang", - "y" : 2 + "name" : "Feng Chang" }, { "name" : "Kjetil Skotheim", @@ -156,40 +172,43 @@ "y" : 2 }, { - "drilldown" : "Mark Anderson", "y" : 2, - "name" : "Mark Anderson" + "name" : "Mark Anderson", + "drilldown" : "Mark Anderson" }, { "drilldown" : "Niels van Dijke", - "y" : 2, - "name" : "Niels van Dijke" + "name" : "Niels van Dijke", + "y" : 2 }, { - "y" : 2, "drilldown" : "Paulo Custodio", - "name" : "Paulo Custodio" + "name" : "Paulo Custodio", + "y" : 2 }, { - "drilldown" : "Peter Campbell Smith", "y" : 3, + "drilldown" : "Peter Campbell Smith", "name" : "Peter Campbell Smith" }, { - "name" : "Peter Meszaros", + "y" : 2, "drilldown" : "Peter Meszaros", - "y" : 2 + "name" : "Peter Meszaros" + }, + { + "drilldown" : "Ulrich Rieke", + "name" : "Ulrich Rieke", + "y" : 4 } ], + "name" : "The Weekly Challenge - 283", "colorByPoint" : 1 } ], "tooltip" : { - "pointFormat" : "{point.name}: {point.y:f}
", + "followPointer" : 1, "headerFormat" : "{series.name}
", - "followPointer" : 1 - }, - "xAxis" : { - "type" : "category" + "pointFormat" : "{point.name}: {point.y:f}
" } } diff --git a/stats/pwc-language-breakdown-2019.json b/stats/pwc-language-breakdown-2019.json index 135b7f4f7a..b138834518 100644 --- a/stats/pwc-language-breakdown-2019.json +++ b/stats/pwc-language-breakdown-2019.json @@ -1,8 +1,11 @@ { + "subtitle" : { + "text" : "Click the columns to drilldown the language breakdown. Last updated at 2024-08-19 13:33:03 GMT" + }, "drilldown" : { "series" : [ { - "id" : "041", + "name" : "041", "data" : [ [ "Perl", @@ -17,7 +20,7 @@ 9 ] ], - "name" : "041" + "id" : "041" }, { "data" : [ @@ -34,11 +37,12 @@ 10 ] ], - "name" : "040", - "id" : "040" + "id" : "040", + "name" : "040" }, { "name" : "039", + "id" : "039", "data" : [ [ "Perl", @@ -52,8 +56,7 @@ "Blog", 12 ] - ], - "id" : "039" + ] }, { "name" : "038", @@ -88,11 +91,11 @@ 9 ] ], - "name" : "037", - "id" : "037" + "id" : "037", + "name" : "037" }, { - "name" : "036", + "id" : "036", "data" : [ [ "Perl", @@ -107,11 +110,9 @@ 11 ] ], - "id" : "036" + "name" : "036" }, { - "id" : "035", - "name" : "035", "data" : [ [ "Perl", @@ -125,9 +126,12 @@ "Blog", 9 ] - ] + ], + "id" : "035", + "name" : "035" }, { + "id" : "034", "data" : [ [ "Perl", @@ -142,11 +146,9 @@ 11 ] ], - "name" : "034", - "id" : "034" + "name" : "034" }, { - "id" : "033", "data" : [ [ "Perl", @@ -161,9 +163,11 @@ 10 ] ], + "id" : "033", "name" : "033" }, { + "name" : "032", "data" : [ [ "Perl", @@ -178,7 +182,6 @@ 10 ] ], - "name" : "032", "id" : "032" }, { @@ -200,7 +203,7 @@ "id" : "031" }, { - "id" : "030", + "name" : "030", "data" : [ [ "Perl", @@ -215,7 +218,7 @@ 10 ] ], - "name" : "030" + "id" : "030" }, { "data" : [ @@ -232,10 +235,11 @@ 12 ] ], - "name" : "029", - "id" : "029" + "id" : "029", + "name" : "029" }, { + "name" : "028", "data" : [ [ "Perl", @@ -250,11 +254,9 @@ 9 ] ], - "name" : "028", "id" : "028" }, { - "id" : "027", "name" : "027", "data" : [ [ @@ -269,9 +271,11 @@ "Blog", 9 ] - ] + ], + "id" : "027" }, { + "name" : "026", "id" : "026", "data" : [ [ @@ -286,10 +290,10 @@ "Blog", 10 ] - ], - "name" : "026" + ] }, { + "name" : "025", "data" : [ [ "Perl", @@ -304,10 +308,11 @@ 12 ] ], - "name" : "025", "id" : "025" }, { + "name" : "024", + "id" : "024", "data" : [ [ "Perl", @@ -321,12 +326,9 @@ "Blog", 11 ] - ], - "name" : "024", - "id" : "024" + ] }, { - "id" : "023", "data" : [ [ "Perl", @@ -341,10 +343,10 @@ 12 ] ], + "id" : "023", "name" : "023" }, { - "name" : "022", "data" : [ [ "Perl", @@ -359,10 +361,12 @@ 10 ] ], - "id" : "022" + "id" : "022", + "name" : "022" }, { "name" : "021", + "id" : "021", "data" : [ [ "Perl", @@ -376,10 +380,11 @@ "Blog", 10 ] - ], - "id" : "021" + ] }, { + "name" : "020", + "id" : "020", "data" : [ [ "Perl", @@ -393,9 +398,7 @@ "Blog", 13 ] - ], - "name" : "020", - "id" : "020" + ] }, { "id" : "019", @@ -434,8 +437,8 @@ "id" : "018" }, { - "id" : "017", "name" : "017", + "id" : "017", "data" : [ [ "Perl", @@ -452,6 +455,8 @@ ] }, { + "name" : "016", + "id" : "016", "data" : [ [ "Perl", @@ -465,11 +470,10 @@ "Blog", 13 ] - ], - "name" : "016", - "id" : "016" + ] }, { + "id" : "015", "data" : [ [ "Perl", @@ -484,8 +488,7 @@ 15 ] ], - "name" : "015", - "id" : "015" + "name" : "015" }, { "name" : "014", @@ -538,8 +541,8 @@ 11 ] ], - "name" : "012", - "id" : "012" + "id" : "012", + "name" : "012" }, { "id" : "011", @@ -561,6 +564,7 @@ }, { "name" : "010", + "id" : "010", "data" : [ [ "Perl", @@ -574,11 +578,9 @@ "Blog", 11 ] - ], - "id" : "010" + ] }, { - "id" : "009", "name" : "009", "data" : [ [ @@ -593,7 +595,8 @@ "Blog", 13 ] - ] + ], + "id" : "009" }, { "name" : "008", @@ -614,6 +617,7 @@ "id" : "008" }, { + "name" : "007", "data" : [ [ "Perl", @@ -628,12 +632,9 @@ 10 ] ], - "name" : "007", "id" : "007" }, { - "id" : "006", - "name" : "006", "data" : [ [ "Perl", @@ -647,9 +648,12 @@ "Blog", 7 ] - ] + ], + "id" : "006", + "name" : "006" }, { + "name" : "005", "id" : "005", "data" : [ [ @@ -664,11 +668,10 @@ "Blog", 12 ] - ], - "name" : "005" + ] }, { - "id" : "004", + "name" : "004", "data" : [ [ "Perl", @@ -683,10 +686,10 @@ 10 ] ], - "name" : "004" + "id" : "004" }, { - "id" : "003", + "name" : "003", "data" : [ [ "Perl", @@ -701,11 +704,9 @@ 9 ] ], - "name" : "003" + "id" : "003" }, { - "id" : "002", - "name" : "002", "data" : [ [ "Perl", @@ -719,10 +720,11 @@ "Blog", 10 ] - ] + ], + "id" : "002", + "name" : "002" }, { - "name" : "001", "data" : [ [ "Perl", @@ -737,27 +739,45 @@ 12 ] ], - "id" : "001" + "id" : "001", + "name" : "001" } ] }, + "title" : { + "text" : "The Weekly Challenge Language" + }, + "xAxis" : { + "type" : "category" + }, "legend" : { "enabled" : "false" }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "chart" : { + "type" : "column" + }, + "tooltip" : { + "followPointer" : "true", + "headerFormat" : "", + "pointFormat" : "Challenge {point.name}: {point.y:f}
" + }, "series" : [ { - "colorByPoint" : "true", - "name" : "The Weekly Challenge Languages", "data" : [ { - "y" : 80, "drilldown" : "041", - "name" : "041" + "name" : "041", + "y" : 80 }, { - "drilldown" : "040", "y" : 77, - "name" : "040" + "name" : "040", + "drilldown" : "040" }, { "name" : "039", @@ -766,112 +786,112 @@ }, { "y" : 74, - "drilldown" : "038", - "name" : "038" + "name" : "038", + "drilldown" : "038" }, { - "name" : "037", "drilldown" : "037", + "name" : "037", "y" : 70 }, { + "y" : 70, "name" : "036", - "drilldown" : "036", - "y" : 70 + "drilldown" : "036" }, { - "drilldown" : "035", "y" : 68, + "drilldown" : "035", "name" : "035" }, { - "drilldown" : "034", "y" : 70, + "drilldown" : "034", "name" : "034" }, { - "y" : 113, + "name" : "033", "drilldown" : "033", - "name" : "033" + "y" : 113 }, { + "y" : 97, "name" : "032", - "drilldown" : "032", - "y" : 97 + "drilldown" : "032" }, { - "y" : 93, + "name" : "031", "drilldown" : "031", - "name" : "031" + "y" : 93 }, { - "name" : "030", + "y" : 120, "drilldown" : "030", - "y" : 120 + "name" : "030" }, { - "name" : "029", "y" : 83, - "drilldown" : "029" + "drilldown" : "029", + "name" : "029" }, { + "name" : "028", "drilldown" : "028", - "y" : 82, - "name" : "028" + "y" : 82 }, { "y" : 64, - "drilldown" : "027", - "name" : "027" + "name" : "027", + "drilldown" : "027" }, { - "name" : "026", "y" : 75, - "drilldown" : "026" + "drilldown" : "026", + "name" : "026" }, { - "name" : "025", "y" : 62, - "drilldown" : "025" + "drilldown" : "025", + "name" : "025" }, { - "drilldown" : "024", "y" : 77, - "name" : "024" + "name" : "024", + "drilldown" : "024" }, { - "name" : "023", + "y" : 88, "drilldown" : "023", - "y" : 88 + "name" : "023" }, { "drilldown" : "022", - "y" : 72, - "name" : "022" + "name" : "022", + "y" : 72 }, { + "drilldown" : "021", "name" : "021", - "y" : 72, - "drilldown" : "021" + "y" : 72 }, { - "name" : "020", + "y" : 100, "drilldown" : "020", - "y" : 100 + "name" : "020" }, { - "name" : "019", "y" : 101, + "name" : "019", "drilldown" : "019" }, { - "drilldown" : "018", "y" : 82, - "name" : "018" + "name" : "018", + "drilldown" : "018" }, { - "drilldown" : "017", "y" : 83, + "drilldown" : "017", "name" : "017" }, { @@ -880,43 +900,43 @@ "name" : "016" }, { - "y" : 95, + "name" : "015", "drilldown" : "015", - "name" : "015" + "y" : 95 }, { + "drilldown" : "014", "name" : "014", - "y" : 98, - "drilldown" : "014" + "y" : 98 }, { + "name" : "013", "drilldown" : "013", - "y" : 85, - "name" : "013" + "y" : 85 }, { "name" : "012", - "y" : 90, - "drilldown" : "012" + "drilldown" : "012", + "y" : 90 }, { - "drilldown" : "011", "y" : 86, - "name" : "011" + "name" : "011", + "drilldown" : "011" }, { + "drilldown" : "010", "name" : "010", - "y" : 69, - "drilldown" : "010" + "y" : 69 }, { - "y" : 79, "drilldown" : "009", - "name" : "009" + "name" : "009", + "y" : 79 }, { - "name" : "008", "drilldown" : "008", + "name" : "008", "y" : 82 }, { @@ -926,23 +946,23 @@ }, { "name" : "006", - "y" : 63, - "drilldown" : "006" + "drilldown" : "006", + "y" : 63 }, { - "drilldown" : "005", "y" : 82, + "drilldown" : "005", "name" : "005" }, { - "name" : "004", "drilldown" : "004", + "name" : "004", "y" : 106 }, { "name" : "003", - "y" : 91, - "drilldown" : "003" + "drilldown" : "003", + "y" : 91 }, { "name" : "002", @@ -950,42 +970,22 @@ "y" : 133 }, { - "name" : "001", + "y" : 165, "drilldown" : "001", - "y" : 165 + "name" : "001" } - ] + ], + "name" : "The Weekly Challenge Languages", + "colorByPoint" : "true" } ], - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } - }, - "tooltip" : { - "followPointer" : "true", - "headerFormat" : "", - "pointFormat" : "Challenge {point.name}: {point.y:f}
" - }, - "xAxis" : { - "type" : "category" - }, - "subtitle" : { - "text" : "Click the columns to drilldown the language breakdown. Last updated at 2024-08-19 12:34:56 GMT" - }, - "title" : { - "text" : "The Weekly Challenge Language" - }, "plotOptions" : { "series" : { - "borderWidth" : 0, "dataLabels" : { - "format" : "{point.y}", - "enabled" : 1 - } + "enabled" : 1, + "format" : "{point.y}" + }, + "borderWidth" : 0 } - }, - "chart" : { - "type" : "column" } } diff --git a/stats/pwc-language-breakdown-2020.json b/stats/pwc-language-breakdown-2020.json index 30e7b5194e..554030a34c 100644 --- a/stats/pwc-language-breakdown-2020.json +++ b/stats/pwc-language-breakdown-2020.json @@ -1,17 +1,4 @@ { - "tooltip" : { - "pointFormat" : "Challenge {point.name}: {point.y:f}
", - "followPointer" : "true", - "headerFormat" : "" - }, - "xAxis" : { - "type" : "category" - }, - "yAxis" : { - "title" : { - "text" : "Total Solutions" - } - }, "drilldown" : { "series" : [ { @@ -33,8 +20,8 @@ "id" : "093" }, { - "id" : "092", "name" : "092", + "id" : "092", "data" : [ [ "Perl", @@ -51,7 +38,7 @@ ] }, { - "name" : "091", + "id" : "091", "data" : [ [ "Perl", @@ -66,10 +53,9 @@ 16 ] ], - "id" : "091" + "name" : "091" }, { - "id" : "090", "data" : [ [ "Perl", @@ -84,9 +70,11 @@ 17 ] ], + "id" : "090", "name" : "090" }, { + "name" : "089", "data" : [ [ "Perl", @@ -101,7 +89,6 @@ 20 ] ], - "name" : "089", "id" : "089" }, { @@ -123,7 +110,6 @@ "id" : "088" }, { - "id" : "087", "data" : [ [ "Perl", @@ -138,6 +124,7 @@ 14 ] ], + "id" : "087", "name" : "087" }, { @@ -191,10 +178,12 @@ 12 ] ], - "name" : "084", - "id" : "084" + "id" : "084", + "name" : "084" }, { + "name" : "083", + "id" : "083", "data" : [ [ "Perl", @@ -208,11 +197,10 @@ "Blog", 16 ] - ], - "name" : "083", - "id" : "083" + ] }, { + "id" : "082", "data" : [ [ "Perl", @@ -227,11 +215,11 @@ 17 ] ], - "name" : "082", - "id" : "082" + "name" : "082" }, { "name" : "081", + "id" : "081", "data" : [ [ "Perl", @@ -245,11 +233,10 @@ "Blog", 15 ] - ], - "id" : "081" + ] }, { - "name" : "080", + "id" : "080", "data" : [ [ "Perl", @@ -264,11 +251,9 @@ 16 ] ], - "id" : "080" + "name" : "080" }, { - "id" : "079", - "name" : "079", "data" : [ [ "Perl", @@ -282,10 +267,12 @@ "Blog", 17 ] - ] + ], + "id" : "079", + "name" : "079" }, { - "name" : "078", + "id" : "078", "data" : [ [ "Perl", @@ -300,10 +287,9 @@ 18 ] ], - "id" : "078" + "name" : "078" }, { - "id" : "077", "name" : "077", "data" : [ [ @@ -318,7 +304,8 @@ "Blog", 14 ] - ] + ], + "id" : "077" }, { "data" : [ @@ -335,11 +322,11 @@ 16 ] ], - "name" : "076", - "id" : "076" + "id" : "076", + "name" : "076" }, { - "name" : "075", + "id" : "075", "data" : [ [ "Perl", @@ -354,9 +341,10 @@ 20 ] ], - "id" : "075" + "name" : "075" }, { + "name" : "074", "id" : "074", "data" : [ [ @@ -371,10 +359,11 @@ "Blog", 20 ] - ], - "name" : "074" + ] }, { + "name" : "073", + "id" : "073", "data" : [ [ "Perl", @@ -388,12 +377,9 @@ "Blog", 17 ] - ], - "name" : "073", - "id" : "073" + ] }, { - "id" : "072", "name" : "072", "data" : [ [ @@ -408,7 +394,8 @@ "Blog", 19 ] - ] + ], + "id" : "072" }, { "id" : "071", @@ -429,7 +416,6 @@ "name" : "071" }, { - "id" : "070", "data" : [ [ "Perl", @@ -444,10 +430,10 @@ 17 ] ], + "id" : "070", "name" : "070" }, { - "id" : "069", "data" : [ [ "Perl", @@ -462,6 +448,7 @@ 16 ] ], + "id" : "069", "name" : "069" }, { @@ -479,10 +466,11 @@ 13 ] ], - "name" : "068", - "id" : "068" + "id" : "068", + "name" : "068" }, { + "name" : "067", "data" : [ [ "Perl", @@ -497,11 +485,9 @@ 18 ] ], - "name" : "067", "id" : "067" }, { - "id" : "066", "data" : [ [ "Perl", @@ -516,6 +502,7 @@ 14 ] ], + "id" : "066", "name" : "066" }, { @@ -537,7 +524,6 @@ "id" : "065" }, { - "id" : "064", "name" : "064", "data" : [ [ @@ -552,10 +538,11 @@ "Blog", 16 ] - ] + ], + "id" : "064" }, { - "id" : "063", + "name" : "063", "data" : [ [ "Perl", @@ -570,9 +557,10 @@ 13 ] ], - "name" : "063" + "id" : "063" }, { + "name" : "062", "data" : [ [ "Perl", @@ -587,7 +575,6 @@ 11 ] ], - "name" : "062", "id" : "062" }, { @@ -605,10 +592,12 @@ 14 ] ], - "name" : "061", - "id" : "061" + "id" : "061", + "name" : "061" }, { + "name" : "060", + "id" : "060", "data" : [ [ "Perl", @@ -622,12 +611,11 @@ "Blog", 16 ] - ], - "name" : "060", - "id" : "060" + ] }, { "name" : "059", + "id" : "059", "data" : [ [ "Perl", @@ -641,11 +629,10 @@ "Blog", 16 ] - ], - "id" : "059" + ] }, { - "id" : "058", + "name" : "058", "data" : [ [ "Perl", @@ -660,11 +647,11 @@ 13 ] ], - "name" : "058" + "id" : "058" }, { - "id" : "057", "name" : "057", + "id" : "057", "data" : [ [ "Perl", @@ -681,7 +668,6 @@ ] }, { - "id" : "056", "name" : "056", "data" : [ [ @@ -696,10 +682,10 @@ "Blog", 17 ] - ] + ], + "id" : "056" }, { - "id" : "055", "data" : [ [ "Perl", @@ -714,6 +700,7 @@ 14 ] ], + "id" : "055", "name" : "055" }, { @@ -735,7 +722,6 @@ "id" : "054" }, { - "id" : "053", "data" : [ [ "Perl", @@ -750,10 +736,11 @@ 15 ] ], + "id" : "053", "name" : "053" }, { - "name" : "052", + "id" : "052", "data" : [ [ "Perl", @@ -768,10 +755,11 @@ 14 ] ], - "id" : "052" + "name" : "052" }, { "name" : "051", + "id" : "051", "data" : [ [ "Perl", @@ -785,11 +773,9 @@ "Blog", 11 ] - ], - "id" : "051" + ] }, { - "id" : "050", "data" : [ [ "Perl", @@ -804,10 +790,11 @@ 12 ] ], + "id" : "050", "name" : "050" }, { - "id" : "049", + "name" : "049", "data" : [ [ "Perl", @@ -822,10 +809,10 @@ 12 ] ], - "name" : "049" + "id" : "049" }, { - "id" : "048", + "name" : "048", "data" : [ [ "Perl", @@ -840,7 +827,7 @@ 12 ] ], - "name" : "048" + "id" : "048" }, { "id" : "047", @@ -861,6 +848,8 @@ "name" : "047" }, { + "name" : "046", + "id" : "046", "data" : [ [ "Perl", @@ -874,12 +863,9 @@ "Blog", 10 ] - ], - "name" : "046", - "id" : "046" + ] }, { - "id" : "045", "data" : [ [ "Perl", @@ -894,10 +880,12 @@ 11 ] ], + "id" : "045", "name" : "045" }, { "name" : "044", + "id" : "044", "data" : [ [ "Perl", @@ -911,12 +899,9 @@ "Blog", 11 ] - ], - "id" : "044" + ] }, { - "id" : "043", - "name" : "043", "data" : [ [ "Perl", @@ -930,10 +915,11 @@ "Blog", 11 ] - ] + ], + "id" : "043", + "name" : "043" }, { - "id" : "042", "data" : [ [ "Perl", @@ -948,100 +934,122 @@ 11 ] ], + "id" : "042", "name" : "042" } ] }, + "subtitle" : { + "text" : "Click the columns to drilldown the language breakdown. Last updated at 2024-08-19 13:33:03 GMT" + }, + "title" : { + "text" : "The Weekly Challenge Language" + }, + "xAxis" : { + "type" : "category" + }, "legend" : { "enabled" : "false" }, + "chart" : { + "type" : "column" + }, + "yAxis" : { + "title" : { + "text" : "Total Solutions" + } + }, + "tooltip" : { + "pointFormat" : "Challenge {point.name}: {point.y:f}
", + "followPointer" : "true", + "headerFormat" : "" + }, "series" : [ { - "colorByPoint" : "true", "data" : [ { - "name" : "093", "drilldown" : "093", + "name" : "093", "y" : 87 }, { - "name" : "092", "drilldown" : "092", + "name" : "092", "y" : 98 }, { - "name" : "091", "drilldown" : "091", + "name" : "091", "y" : 108 }, { - "drilldown" : "090", "y" : 113, - "name" : "090" + "name" : "090", + "drilldown" : "090" }, { + "drilldown" : "089", "name" : "089", - "y" : 113, - "drilldown" : "089" + "y" : 113 }, { "y" : 121, - "drilldown" : "088", - "name" : "088" + "name" : "088", + "drilldown" : "088" }, { "drilldown" : "087", - "y" : 101, - "name" : "087" + "name" : "087", + "y" : 101 }, { - "name" : "086", "drilldown" : "086", + "name" : "086", "y" : 104 }, { + "y" : 113, "name" : "085", - "drilldown" : "085", - "y" : 113 + "drilldown" : "085" }, { - "name" : "084", "drilldown" : "084", + "name" : "084", "y" : 119 }, { - "name" : "083", "y" : 127, + "name" : "083", "drilldown" : "083" }, { "name" : "082", - "y" : 114, - "drilldown" : "082" + "drilldown" : "082", + "y" : 114 }, { - "name" : "081", "y" : 114, + "name" : "081", "drilldown" : "081" }, { "name" : "080", - "y" : 127, - "drilldown" : "080" + "drilldown" : "080", + "y" : 127 }, { - "y" : 122, "drilldown" : "079", - "name" : "079" + "name" : "079", + "y" : 122 }, { - "y" : 127, + "name" : "078", "drilldown" : "078", - "name" : "078" + "y" : 127 }, { - "drilldown" : "077", "y" : 100, + "drilldown" : "077", "name" : "077" }, { @@ -1051,132 +1059,132 @@ }, { "name" : "075", - "y" : 117, - "drilldown" : "075" + "drilldown" : "075", + "y" : 117 }, { "y" : 117, - "drilldown" : "074", - "name" : "074" + "name" : "074", + "drilldown" : "074" }, { + "y" : 112, "name" : "073", - "drilldown" : "073", - "y" : 112 + "drilldown" : "073" }, { "drilldown" : "072", - "y" : 116, - "name" : "072" + "name" : "072", + "y" : 116 }, { + "drilldown" : "071", "name" : "071", - "y" : 82, - "drilldown" : "071" + "y" : 82 }, { - "drilldown" : "070", "y" : 98, + "drilldown" : "070", "name" : "070" }, { "drilldown" : "069", - "y" : 87, - "name" : "069" + "name" : "069", + "y" : 87 }, { - "name" : "068", "y" : 79, - "drilldown" : "068" + "drilldown" : "068", + "name" : "068" }, { - "y" : 94, + "name" : "067", "drilldown" : "067", - "name" : "067" + "y" : 94 }, { - "drilldown" : "066", "y" : 88, + "drilldown" : "066", "name" : "066" }, { "drilldown" : "065", - "y" : 77, - "name" : "065" + "name" : "065", + "y" : 77 }, { "name" : "064", - "y" : 84, - "drilldown" : "064" + "drilldown" : "064", + "y" : 84 }, { - "y" : 93, "drilldown" : "063", - "name" : "063" + "name" : "063", + "y" : 93 }, { - "y" : 62, "drilldown" : "062", - "name" : "062" + "name" : "062", + "y" : 62 }, { + "name" : "061", "drilldown" : "061", - "y" : 85, - "name" : "061" + "y" : 85 }, { - "drilldown" : "060", "y" : 89, + "drilldown" : "060", "name" : "060" }, { - "y" : 93, + "name" : "059", "drilldown" : "059", - "name" : "059" + "y" : 93 }, { "name" : "058", - "y" : 71, - "drilldown" : "058" + "drilldown" : "058", + "y" : 71 }, { - "name" : "057", "y" : 86, - "drilldown" : "057" + "drilldown" : "057", + "name" : "057" }, { - "y" : 104, + "name" : "056", "drilldown" : "056", - "name" : "056" + "y" : 104 }, { + "y" : 92, "name" : "055", - "drilldown" : "055", - "y" : 92 + "drilldown" : "055" }, { - "drilldown" : "054", "y" : 107, + "drilldown" : "054", "name" : "054" }, { - "drilldown" : "053", "y" : 105, - "name" : "053" + "name" : "053", + "drilldown" : "053" }, { - "y" : 93, + "name" : "052", "drilldown" : "052", - "name" : "052" + "y" : 93 }, { - "name" : "051", "drilldown" : "051", + "name" : "051", "y" : 95 }, { - "name" : "050", "y" : 104, + "name" : "050", "drilldown" : "050" }, { @@ -1185,60 +1193,52 @@ "y" : 93 }, { - "y" : 112, "drilldown" : "048", - "name" : "048" + "name" : "048", + "y" : 112 }, { "name" : "047", - "y" : 88, - "drilldown" : "047" + "drilldown" : "047", + "y" : 88 }, { "name" : "046", - "y" : 93, - "drilldown" : "046" + "drilldown" : "046", + "y" : 93 }, { - "drilldown" : "045", "y" : 102, + "drilldown" : "045", "name" : "045" }, { - "y" : 90, "drilldown" : "044", - "name" : "044" + "name" : "044", + "y" : 90 }, { + "name" : "043", "drilldown" : "043", - "y" : 72, - "name" : "043" + "y" : 72 }, { + "name" : "042", "drilldown" : "042", - "y" : 98, - "name" : "042" + "y" : 98 } ], - "name" : "The Weekly Challenge Languages" + "name" : "The Weekly Challenge Languages", + "colorByPoint" : "true" } ], - "title" : { - "text" : "The Weekly Challenge Language" - }, - "chart" : { - "type" : "column" - }, "plotOptions" : { "series" : { + "borderWidth" : 0, "dataLabels" : { - "enabled" : 1, - "format" : "{point.y}" - }, - "borderWidth" : 0 + "format" : "{point.y}", + "enabled" : 1 + } } - }, - "subtitle" : { - "text" : "Click the columns to drilldown the language breakdown. Last updated at 2024-08-19 12:34:56 GMT" } } diff --git a/stats/pwc-language-breakdown-2021.json b/stats/pwc-language-breakdown-2021.json index be4424ad44..242a4f278f 100644 --- a/stats/pwc-language-breakdown-2021.json +++ b/stats/pwc-language-breakdown-2021.json @@ -1,9 +1,8 @@ { - "subtitle" : { - "text" : "Click the columns to drilldown the language breakdown. Last updated at 2024-08-19 12:34:56 GMT" - }, - "title" : { - "text" : "The Weekly Challenge Language" + "tooltip" : { + "pointFormat" : "Challenge {point.name}: {point.y:f}
", + "headerFormat" : "", + "followPointer" : "true" }, "plotOptions" : { "series" : { @@ -14,14 +13,297 @@ } } }, + "series" : [ + { + "name" : "The Weekly Challenge Languages", + "colorByPoint" : "true", + "data" : [ + { + "drilldown" : 145, + "name" : "145", + "y" : 96 + }, + { + "drilldown" : 144, + "name" : "144", + "y" : 90 + }, + { + "y" : 85, + "drilldown" : 143, + "name" : "143" + }, + { + "drilldown" : 142, + "name" : "142", + "y" : 85 + }, + { + "y" : 102, + "drilldown" : 141, + "name" : "141" + }, + { + "drilldown" : 140, + "name" : "140", + "y" : 103 + }, + { + "y" : 97, + "drilldown" : 139, + "name" : "139" + }, + { + "y" : 102, + "drilldown" : 138, + "name" : "138" + }, + { + "name" : "137", + "drilldown" : 137, + "y" : 100 + }, + { + "name" : "136", + "drilldown" : 136, + "y" : 97 + }, + { + "name" : "135", + "drilldown" : 135, + "y" : 104 + }, + { + "drilldown" : 134, + "name" : "134", + "y" : 94 + }, + { + "y" : 95, + "name" : "133", + "drilldown" : 133 + }, + { + "drilldown" : 132, + "name" : "132", + "y" : 78 + }, + { + "y" : 91, + "drilldown" : 131, + "name" : "131" + }, + { + "drilldown" : 130, + "name" : "130", + "y" : 75 + }, + { + "name" : "129", + "drilldown" : 129, + "y" : 52 + }, + { + "y" : 73, + "name" : "128", + "drilldown" : 128 + }, + { + "drilldown" : 127, + "name" : "127", + "y" : 115 + }, + { + "name" : "126", + "drilldown" : 126, + "y" : 113 + }, + { + "y" : 65, + "drilldown" : 125, + "name" : "125" + }, + { + "y" : 87, + "drilldown" : 124, + "name" : "124" + }, + { + "y" : 105, + "drilldown" : 123, + "name" : "123" + }, + { + "drilldown" : 122, + "name" : "122", + "y" : 110 + }, + { + "y" : 94, + "drilldown" : 121, + "name" : "121" + }, + { + "y" : 116, + "drilldown" : 120, + "name" : "120" + }, + { + "y" : 125, + "drilldown" : 119, + "name" : "119" + }, + { + "drilldown" : 118, + "name" : "118", + "y" : 85 + }, + { + "y" : 99, + "drilldown" : 117, + "name" : "117" + }, + { + "y" : 97, + "drilldown" : 116, + "name" : "116" + }, + { + "y" : 98, + "name" : "115", + "drilldown" : 115 + }, + { + "drilldown" : 114, + "name" : "114", + "y" : 110 + }, + { + "y" : 94, + "drilldown" : 113, + "name" : "113" + }, + { + "y" : 94, + "drilldown" : 112, + "name" : "112" + }, + { + "y" : 93, + "drilldown" : 111, + "name" : "111" + }, + { + "y" : 110, + "drilldown" : 110, + "name" : "110" + }, + { + "drilldown" : 109, + "name" : "109", +