En los Nuevos Tiempos Modernos , cuando Charlie Chaplin se encuentra con una computadora, está empleado en el patio de clasificación, como un validador para determinar si los trabajadores están clasificando correctamente los elementos. Los artículos en cuestión son paquetes de canicas. Los paquetes con un número impar de canicas se apilan en la canasta roja y los paquetes con un número par de canicas se apilan en la canasta azul.
Se supone que Charlie Chaplin golpea el programa que se validaría si hay alguna anomalía en el procedimiento de clasificación. Mack Swain, su jefe inmediato, comparte un algoritmo que necesita 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²)
Su trabajo es determinar el Check_Digit y relacionarlo con el valor que calcula su jefe.
Charlie Chaplin, durante sus horas de almuerzo, pudo escabullirse al cajón de Mack Swain y determinar que su cajón tiene una sola tarjeta con golpes en las primeras 46 32 columnas (lo que significa que Mack pudo escribir un programa con solo 46 32 caracteres).
Charlie Chaplin ahora necesitaría la ayuda de todos los códigos ninja para escribir un programa con la menor cantidad de líneas posible. También anuncia una bonificación de 50 puntos, si alguien puede idear un programa que sea más corto que su Jefe.
Resumen
Dada una lista / matriz / vector de números positivos (pares e impares), debe escribir una función que acepte array(int [])/vector<int>/list
y calcule la raíz de la suma de los cuadrados de las sumas de números impares y pares en la lista.
El tamaño del programa es el tamaño del cuerpo de la función, es decir, excluyendo el tamaño de la firma de la función.
Ejemplo
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
Tenga en cuenta que la salida real puede variar según la precisión de coma flotante de la implementación.
Puntuación
La puntuación se calcula como La puntuación se calcula como Σ(Characters in your Program) - 46
. Σ(Characters in your Program) - 32
. Además de la votación regular de la comunidad, el puntaje negativo más bajo recibiría una bonificación adicional de 50 puntos.
Editar
- La compensación que se usó para calcular el puntaje se cambió de 46 a 32. Tenga en cuenta que esto no afectaría la elegibilidad de la tabla de clasificación / recompensa ni invalidaría ninguna solución.
Veredicto
Después de un horrible duelo entre los Ninjas, el Sr. Chaplin recibió algunas respuestas maravillosas. Lamentablemente, pocas de las respuestas intentaron aprovechar indebidamente la regla y no fueron muy útiles. En realidad, quería un duelo justo y las respuestas donde la lógica estaba codificada dentro de las firmas de funciones eventualmente significarían que la firma de funciones es una parte integral de la solución. Finalmente, Ninja FireFly fue el claro ganador y le otorgó el bono que se merece. Tabla de clasificación (actualizada todos los días)
╒══════╤═════════════════╤══════════════╤═════════╤════════╤═══════╕
├ 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 │
└──────┴─────────────────┴──────────────┴─────────┴────────┴───────┘