Ostatnim razem, gdy próbowałem wymyślić coś łatwego, co nie było duplikatem, okazało się, że jest to zbyt trudne. Mam nadzieję, że tym razem jest to coś nowego.
Wejście:
Tablica / lista z liczbami całkowitymi / dziesiętnymi. (Lub ciąg reprezentujący tablicę z liczbami całkowitymi / dziesiętnymi.)
Wynik:
Zapętlaj liczby i zastosuj następujące pięć operandów matematycznych w tej kolejności:
- Dodawanie (
+
); - Odejmowanie (
−
); - Mnożenie (
*
lub×
lub·
); - Real / Calculator Division (
/
lub÷
); - Potęgowanie (
^
lub**
).
(UWAGA: Symbole między nawiasami zostały dodane tylko jako wyjaśnienie. Jeśli twój język programowania używa zupełnie innego symbolu dla operacji matematycznej niż w przykładach, to jest to oczywiście całkowicie dopuszczalne).
Kontynuuj, aż dojdziesz do końca listy, a następnie podaj wynik sumy.
Zasady konkursu:
- Potęgowanie przez 0 (
n ^ 0
) powinno dać 1 (dotyczy to również0 ^ 0 = 1
). - Nie ma przypadków testowych dla dzielenia przez 0 (
n / 0
), więc nie musisz się martwić o przypadek na krawędzi. - Jeśli tablica zawiera tylko jedną liczbę, zwracamy ją jako wynik.
Główne zasady:
- To jest golf golfowy , więc wygrywa najkrótsza odpowiedź w bajtach.
Nie pozwól, aby języki gry w golfa zniechęcały Cię do publikowania odpowiedzi w językach niekodujących golfa. Spróbuj znaleźć możliwie najkrótszą odpowiedź na „dowolny” język programowania. - Do odpowiedzi odnoszą się standardowe reguły , więc możesz używać STDIN / STDOUT, funkcji / metody z odpowiednimi parametrami, pełnych programów. Twoja decyzja.
- Domyślne luki są zabronione.
- Jeśli to możliwe, dodaj link z testem swojego kodu.
Przypadki testowe:
[1,2,3,4,5] -> 0
-> 1 + 2 = 3
-> 3 - 3 = 0
-> 0 * 4 = 0
-> 0 / 5 = 0
[5,12,23,2,4,4,2,6,7] -> 539
-> 5 + 12 = 17
-> 17 - 23 = -6
-> -6 * 2 = -12
-> -12 / 4 = -3
-> -3 ^ 4 = 81
-> 81 + 2 = 83
-> 83 - 6 = 77
-> 77 * 7 -> 539
[-8,50,3,3,-123,4,17,99,13] -> -1055.356...
-> -8 + 50 = 42
-> 42 - 3 = 39
-> 39 * 3 = 117
-> 117 / -123 = -0.9512...
-> -0.9512... ^ 4 = 0.818...
-> 0.818... + 17 = 17.818...
-> 17.818... - 99 -> -81.181...
-> -81.181... * 13 = -1055.356...
[2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2] -> 256
-> 2 + 2 = 4
-> 4 - 2 = 2
-> 2 * 2 = 4
-> 4 / 2 = 2
-> 2 ^ 2 = 4
-> 4 + 2 = 6
-> 6 - 2 = 4
-> 4 * 2 = 8
-> 8 / 2 = 4
-> 4 ^ 2 = 16
-> 16 + 2 = 18
-> 18 - 2 = 16
-> 16 * 2 = 32
-> 32 / 2 = 16
-> 16 ^ 2 = 256
[1,0,1,0,1,0] -> 1
-> 1 + 0 = 1
-> 1 - 1 = 0
-> 0 * 0 = 0
-> 0 / 1 = 0
-> 0 ^ 0 = 1
[-9,-8,-1] -> -16
-> -9 + -8 = -17
-> -17 - -1 = -16
[0,-3] -> -3
-> 0 + -3 = -3
[-99] -> -99
n ^ 0 = 1
ale 0 ^ n = 0
. Konflikt jest rozwiązywany przez ustawienie n != 0
obu reguł, ale potem pozostaje 0 ^ 0
niezdefiniowany. Istnieje jednak wiele rzeczy, które ładnie układają się w matematyce, jeśli tak 0 ^ 0
jest zdefiniowane 1
. Zobacz szczegóły w Wikipedii .