W New Modern Times , kiedy Charlie Chaplin napotyka komputer, jest on zatrudniony w stoczni sortowania, jako osoba zatwierdzająca, aby ustalić, czy pracownicy prawidłowo sortują przedmioty. Przedmiotowe przedmioty to paczki kulek. Paczki z nieparzystą liczbą kulek są układane w Czerwonym Koszu, a paczki z parzystą liczbą Kul są układane w Niebieskim Koszu.
Charlie Chaplin ma przebić program , który sprawdziłby, czy w procedurze sortowania występuje jakakolwiek anomalia. Mack Swain, jego bezpośredni szef, dzieli algorytm, który musi kodować.
Algorytm
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²)
Jego zadaniem jest określenie Check_Digit i dopasowanie go do wartości, jaką kiedykolwiek oblicza jego Szef.
Charlie Chaplin podczas lunchu był w stanie przekraść się do szuflady Macka Swaina i ustalić, że jego szuflada ma pojedynczą kartę ze stemplami w pierwszych 46 32 kolumnach (co oznacza, że Mack był w stanie napisać program zawierający tylko 46 32 znaki).
Charlie Chaplin potrzebowałby teraz pomocy wszystkich ninja-kodów, aby napisać program z jak najmniejszą liczbą wierszy. Ogłasza także bonus 50 punktów, jeśli ktoś może wymyślić program krótszy niż jego Szef.
streszczenie
Biorąc pod uwagę listę / tablicę / wektor liczb dodatnich (nieparzyste i parzyste), musisz napisać funkcję, która akceptuje array(int [])/vector<int>/list
i oblicza pierwiastek z sumy kwadratów sum liczb nieparzystych i parzystych na liście.
Rozmiar programu to rozmiar treści funkcji, tzn. Z wyłączeniem rozmiaru podpisu funkcji.
Przykład
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
Uwaga: rzeczywista wydajność może się różnić w zależności od precyzji zmiennoprzecinkowej implementacji.
Wynik
Wynik obliczany jest jako Wynik obliczany jest jako Σ(Characters in your Program) - 46
. Σ(Characters in your Program) - 32
. Oprócz regularnego głosowania społeczności, najniższy wynik ujemny otrzymałby dodatkowy bonus 50 punktów.
Edytować
- Przesunięcie użyte do obliczenia wyniku zostało zmienione z 46 na 32. Uwaga, nie wpłynie to na kwalifikację do tabeli liderów / nagrody lub nie unieważni żadnego rozwiązania.
Werdykt
Po makabrycznym pojedynku pomiędzy Ninja, pan Chaplin otrzymał wspaniałe odpowiedzi. Niestety niewiele odpowiedzi próbowało w niewłaściwy sposób wykorzystać tę zasadę i nie było zbyt przydatne. Naprawdę chciał uczciwego pojedynku, a odpowiedzi, w których logika została zakodowana w podpisach funkcji, oznaczałyby, że podpis funkcji jest integralną częścią rozwiązania. Wreszcie, Ninja FireFly był wyraźnym zwycięzcą i przyznał mu premię, na którą zasługuje. Tabela liderów (aktualizowana codziennie)
╒══════╤═════════════════╤══════════════╤═════════╤════════╤═══════╕
├ 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 │
└──────┴─────────────────┴──────────────┴─────────┴────────┴───────┘