No New Modern Times , quando Charlie Chaplin encontra um computador, ele é empregado no pátio de classificação, como um validador para determinar se os trabalhadores estão classificando corretamente os itens. Os itens em questão são pacotes de bolinhas de gude. Pacotes com número ímpar de bolinhas de gude são empilhados na cesta vermelha e pacotes com número par de bolinhas de gude são empilhados na cesta azul.
Charlie Chaplin deveria perfurar o programa que seria validado se houver alguma anomalia no processo de classificação. Mack Swain, seu chefe imediato, compartilha um algoritmo que ele precisa codificar.
Algoritmo
L = List of Marble packets that's already sorted
L_ODD = List of packets with Odd Number of Marbles
L_EVEN = List of packets with Even Number of Marbles
Check_Digit = √(ΣL_ODD² + ΣL_EVEN²)
Seu trabalho é determinar o Check_Digit e combiná-lo com o valor que seu chefe calcular.
Charlie Chaplin, durante o horário de almoço, conseguiu esgueirar-se para a gaveta de Mack Swain e determinar que sua gaveta tem um único cartão com socos nas primeiras 46 32 colunas (o que significa que Mack foi capaz de escrever um programa com apenas 46 32 caracteres).
Agora, Charlie Chaplin precisaria da ajuda de todos os ninjas de código para escrever um programa com o menor número possível de linhas. Ele também anuncia um bônus de 50 pontos, se alguém puder criar um programa mais curto que o seu chefe.
Sumário
Dada uma lista / matriz / vetor de números positivos (ímpar e par), você precisa escrever uma função que aceite array(int [])/vector<int>/list
e calcule a raiz da soma dos quadrados das somas de números pares e ímpares na lista.
O tamanho do programa é o tamanho do corpo da função, ou seja, excluindo o tamanho da assinatura da função.
Exemplo
List = [20, 9, 4, 5, 5, 5, 15, 17, 20, 9]
Odd = [9, 5, 5, 5, 15, 17, 9]
Even = [20, 4, 20]
Check_Digit = √(ΣOdd² + ΣEven²) = 78.49203781276162
Observe que a saída real pode variar com base na precisão do ponto flutuante da implementação.
Ponto
A pontuação é calculada como A pontuação é calculada como Σ(Characters in your Program) - 46
. Σ(Characters in your Program) - 32
. Além da votação regular da comunidade, a menor pontuação negativa receberia um bônus adicional de 50 pontos.
Editar
- O deslocamento usado para calcular a pontuação foi alterado de 46 para 32. Observe que isso não afetaria a elegibilidade do quadro de líderes / recompensa ou invalidaria qualquer solução.
Veredito
Após um terrível duelo entre os Ninjas, o Sr. Chaplin recebeu algumas respostas maravilhosas. Infelizmente, algumas das respostas tentaram tirar vantagem indevida da regra e não foram muito úteis. Na verdade, ele queria um duelo justo e respostas em que a lógica fosse codificada nas assinaturas de funções acabariam significando que a assinatura da função é parte integrante da solução. Finalmente, Ninja FireFly foi o vencedor e concedeu a ele o bônus que ele merece. Classificação (atualizada todos os dias)
╒══════╤═════════════════╤══════════════╤═════════╤════════╤═══════╕
├ Rank │ Ninja │ Dialect │ Punches │ Scores │ Votes ┤
╞══════╪═════════════════╪══════════════╪═════════╪════════╪═══════╡
│ 0 │ FireFly │ J │ 17 │ -15 │ 6 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 1 │ tmartin │ Kona │ 22 │ -10 │ 2 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 2 │ Sven Hohenstein │ R │ 24 │ -8 │ 7 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 3 │ Ben Reich │ GolfScript │ 30 │ -2 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 4 │ mollmerx │ k │ 31 │ -1 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 5 │ David Carraher │ Mathematica │ 31 │ -1 │ 3 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 6 │ tmartin │ Q │ 34 │ 2 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 7 │ daniero │ dc │ 35 │ 3 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 8 │ psion5mx │ Python │ 38 │ 6 │ 2 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 9 │ O-I │ Ruby │ 39 │ 7 │ 5 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 10 │ gggg │ Julia │ 40 │ 8 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 11 │ FakeRainBrigand │ LiveScript │ 50 │ 18 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 12 │ Sylwester │ Perl5 │ 50 │ 18 │ 2 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 13 │ daniero │ Ruby │ 55 │ 23 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 14 │ vasuakeel │ Coffeescript │ 57 │ 25 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 15 │ dirkk │ XQuery │ 63 │ 31 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 16 │ crazedgremlin │ Haskell │ 64 │ 32 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 17 │ Uri Agassi │ Ruby │ 66 │ 34 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 18 │ Sumedh │ JAVA │ 67 │ 35 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 19 │ Danny │ Javascript │ 67 │ 35 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 20 │ deroby │ c# │ 69 │ 37 │ 1 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 21 │ Adam Speight │ VB │ 70 │ 38 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 22 │ Andrakis │ Erlang │ 82 │ 50 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 23 │ Sp0T │ PHP │ 85 │ 53 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 24 │ brendanb │ Clojure │ 87 │ 55 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 25 │ Merin Nakarmi │ C# │ 174 │ 142 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 26 │ Boopathi │ JAVA │ 517 │ 485 │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 27 │ Noyo │ ES6 │ ? │ ? │ 2 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 28 │ shiona │ Haskell │ ? │ ? │ 0 │
├──────┼─────────────────┼──────────────┼─────────┼────────┼───────┤
│ 29 │ Vivek │ int │ ? │ ? │ 0 │
└──────┴─────────────────┴──────────────┴─────────┴────────┴───────┘