Parzystość sumy innych elementów

23

Zadanie

Biorąc pod uwagę tablicę dodatnich liczb całkowitych, zamień każdy element na parzystość sumy pozostałych elementów. Tablica ma co najmniej 2 elementy.

Definicja

  • Parzystość: czy liczba jest nieparzysta, czy parzysta.

Przykład

Dla tablicy [1,2,3,1]:

  • Zamień 1na parzystość 2+3+1, tj even.
  • Zamień 2na parzystość 1+3+1, tj odd.
  • Zamień 3na parzystość 1+2+1, tj even.
  • Zamień 1na parzystość 1+2+3, tj even.

Wydajność: [even, odd, even, even]

Wkład

Tablica dodatnich liczb całkowitych.

Możesz wziąć go jako odpowiednią tablicę lub jako ciąg liczb całkowitych dodatnich oddzielonych od linii.

Możesz założyć, że tablica i zawarte w niej wartości mieszczą się w możliwościach obsługi twojego języka.

Wydajność

Tablica dwóch spójnych wartości , jedna reprezentująca odd, jedna reprezentująca even.

Możesz wyprowadzić go jako ciąg znaków oddzielony wierszem dwóch wartości.

Przypadki testowe

Wejścia:

[1, 2, 3, 1]
[1, 2, 3, 2, 1]
[2, 2]
[100, 1001]

Wyjścia:

[even, odd, even, even]
[even, odd, even, odd, even]
[even, even]
[odd, even]

Uwaga: możesz wybrać inne spójne wartości inne niż oddi even.

Punktacja

To jest . Najkrótsza odpowiedź w bajtach wygrywa.

Obowiązuje standardowa luka .

Leaky Nun
źródło

Odpowiedzi:

16

Galaretka , 3 bajty

+SḂ

Wypróbuj online!

Jak to działa

+SḂ  Main link. Argument: A (array)

 S   Compute the sum of A.
+    Add the sum to each element of A.
     Using _ (subtraction) or ^ (bitwise XOR) would also work.
  Ḃ  Bit; compute the parity of each resulting integer.
Dennis
źródło
To sprytne podejście.
Leaky Nun
1
@LeakyNun To samo podejście stosuje wszyscy, tylko krócej: P
ETHproductions
@ETHproductions Prawie tak. Te są tylko tak wieloma sposobami na obliczenie parzystości ...
Dennis
@ETHproductions używa dodawania zamiast odejmowania ...
Leaky Nun
@LeakyNun Prawda, moja odpowiedź Japt również. W _SḂ
Galaretce
8

JavaScript (ES6), 38 36 32 bajtów

a=>a.map(b=>eval(a.join`+`)-b&1)

Używa 0parzystych i 1nieparzystych.

Test

f=
a=>a.map(b=>eval(a.join`+`)-b&1)
console.log(f([1, 2, 3, 1]))
console.log(f([1, 2, 3, 2, 1]))
console.log(f([100, 1001]))

Luke
źródło
2 bajty wyłączone: c-b&1zamiast(c-b)%2
Leaky Nun
Bah! Pobiłeś mnie do tego!
Shaggy
1
Będę musiał pamiętać, aby zużyć eval(a.join`+`)ponad a.reduce((x,y)=>x+y). To sprytne
Cyoce
8

Haskell, 20 bajtów

f x=odd.(sum x-)<$>x

Wykorzystuje Truewartości nieparzyste i Falseparzyste.

Wypróbuj online!

Odejmij każdy element od sumy listy i sprawdź, czy jest nieparzysty.

fzwrócił się do pointfree posiada również 20 bajtów: map=<<(odd.).(-).sum.

nimi
źródło
6

MATL , 5 , 4 bajty

ts-o

Wypróbuj online!

Jeden bajt zapisany dzięki Dennisowi!

Daje to „1” dla nieparzystych i „0” dla parzystych. Wyjaśnienie:

t       % Duplicate the input
 s      % Get the sum of the input
  -     % Subtract it from the original input
   o    % Get the parity of each element
DJMcMayhem
źródło
6

Alice , 31 28 bajtów

/O.HQ\d$K@
\i#\ /d2-&+!w?+2%

Wypróbuj online!

Format wejściowy nie ma znaczenia, o ile liczby całkowite są rozdzielone. Format wyjściowy jest oddzielony od linii.

Układ prawdopodobnie nie jest jeszcze optymalny, ale nie znalazłem jeszcze sposobu na jego dalsze skrócenie.

Wyjaśnienie

/     Reflect to SE. Switch to Ordinal.
i     Read all input as a string.
      Reflect off bottom boundary. Move to NE.
.     Duplicate the input string.
      Reflect off top boundary. Move to SE.
\     Reflect to N. Switch to Cardinal.
H     Implicitly convert the top copy of the input to the integers it
      contains and take the absolute value of the top-most one. (Taking
      the absolute value doesn't do anything, but we need the implicit
      conversion to integers.)
      The IP wraps back to the second line.
\     Reflect to SE. Switch to Ordinal.
      Immediately reflect off bottom boundary. Move to NE.
Q     Reverse the stack (this converts the integers back to strings but
      that's irrelevant). After this, we end up with all the individual
      integers on the bottom of the stack in reverse order and the other
      copy of the input string with all integers on top.
      Reflect off top boundary. Move to SE.
/     Reflect to E. Switch to Cardinal.
d     Push the stack depth, which is one more than the number of list
      elements (due to the other input string on the stack).
2-    Subtract 2.
&+    Run + that many times, which implicitly converts the second string
      to the integers it contains and then adds up all the list elements.
!     Store the sum on the tape.
w     Push the current IP position to the return address stack. This
      lets us return here repeatedly to implement a loop.

  ?+    Retrieve the input sum from the tape and add it to the current
        element.
  2%    Compute its parity. Other ways to do this are 1A and 0x. 2F would
        also work but it gives 0/2 instead of 0/1.
        The IP wraps the first column of the grid.
  \     Reflect to NE. Switch to Ordinal. The IP bounces diaginally up
        and down until it hits the next \.
  O     Implicitly convert the current parity to a string and print it
        with a trailing linefeed.
  #     Skip the next command (the H).
  \     Reflect to E. Switch to Cardinal.
  d     Push the stack depth. This is zero when we're done.
  $     Skip the next command if the stack depth is indeed zero, which
        exits the loop.

K     Jump to the return address on top of the return address stack without
      popping it (so that the next K will jump there again).

@     Terminate the program.
Martin Ender
źródło
6

Pyth, 7 6 bajtów

mi2-sQ

-1 bajtów dzięki @KZhang

Wyjścia 1 dla nieparzystych, 2 dla parzystych.

Spróbuj!

Wyjaśnienie

m%-sQd2
m      Q    # For each element in the (implicit) input list
   sQ       # Take the sum of all the elements
  -  d      # subtract that element, so that we now have the sum of the other elements
 %    2     # modulo 2; 1=off, 0=even
KarlKastor
źródło
Zmieniając modulo %_2na GCD i2_, możesz nawet dokonać dniejawnej zmiany kodu na mi2-sQ, oszczędzając bajt. Wyjścia są zmieniane na 2 na parzyste i 1 na nieparzyste.
K Zhang
5

Python 2 , 33 31 bajtów

-2 bajty dzięki Leaky Nun

lambda x:[sum(x)-z&1for z in x]

Wypróbuj online!

Pręt
źródło
2 bajty wyłączone: sum(x)-z&1zamiast(sum(x)-z)%2
Leaky Nun
3
sum(x,z)%2działałoby również
xnor
4

R, 21 bajtów

(sum(n<-scan())-n)%%2

czyta listę ze standardowego wejścia i zwraca 0 dla parzystej, 1 dla nieparzystej. wiąże dane wejściowe ze zmienną nwewnątrz wywołania sumzamiast wywoływać je na zewnątrz, tj.n=scan();(sum(n)-n)%%2

Wypróbuj online!

Giuseppe
źródło
3

Mathematica, 13 bajtów

#+Tr@#&/*OddQ

lub

OddQ[#+Tr@#]&
Martin Ender
źródło
3

Clojure, 30 bajtów

#(for[i %](odd?(apply - i %)))

Odejmuje wszystkie wartości kolejno od każdej wartości, na przykład przy wprowadzaniu [a b c d]druga obliczona wartość to b - a - b - c - d= -(a + c + d). Wyjście jest falseparzyste i truenieparzyste.

Ale równie dobrze możesz użyć +i obliczyć każdy kolejny termin dwa razy, aby nie wpływał on na parzystość.

NikoNyrh
źródło
3

CJam , 10 bajtów

{_:+f+1f&}

Jest to anonimowy blok (funkcja), który pobiera dane wejściowe ze stosu i zastępuje je danymi wyjściowymi.

Wypróbuj online!

Wyjaśnienie

Rozważ wejście [1 2 3 1] .

{         e# Begin block
          e#   STACK: [1 2 3 1]
  _       e#   Duplicate
          e#   STACK: [1 2 3 1], [1 2 3 1]
  :+      e#   Fold addition over the array: compute its sum
          e#   STACK: [1 2 3 1], 7 
  f+      e#   Map addition over the array with extra parameter
          e#   STACK: [8 10 11 8]
  1       e#   Push 1
          e#   STACK: [8 10 11 8], 1
  f&      e#   Map bit-wise "and" over the array with extra parameter
          e#   STACK: [0 0 1 0]
}         e# End block
Luis Mendo
źródło
2

Japt , 7 bajtów

£x +X&1

Wypróbuj online!

Wyjaśnienie

 £   x +X&1
 mX{ x +X&1}  // Ungolfed
UmX{Ux +X&1}  // Variable introduction

UmX{       }  // Replace each item in the input array with
         &1   //   the parity of
    Ux        //   the sum of the input array
       +X     //   plus X.
              // Implicit: output result of last expression
ETHprodukcje
źródło
2

Perl 5, 31 bajtów

sub{map$x+=$_,@_;map$x-$_&1,@_}

Wyjścia 1dla nieparzystych i 0parzystych.

Chris
źródło
+1, miło. Myślę, że jest to 28 bajtów: perldoc perlsubmówi : „Podpis jest częścią ciała podprogramu. Zwykle ciało podprogramu jest po prostu wzmocnionym blokiem kodu”.
msh210
@ msh210 Thanks! Nie sądzę, że tak to działa, ale na pewno podprogram ma tylko 28 bajtów, ale nie można go pominąć subbez jego złamania.
Chris
Ale czasami podprogram działa bez sub, na przykład po sortlub greplub jako argument do innego podprogramu. Może warto o to zapytać na Code Golf Meta .
msh210
@ msh210 Podprogram działa subtylko wtedy, gdy jest używany w prototypowanej funkcji ( sorti grepjest mniej lub bardziej prototypowany). Ale w przeciwnym razie subjest to wymagane. Niezależnie od tego pominięcie gry w golfa o 3 bajty subnie jest naprawdę interesujące.
Dada
2

Clojure (skrypt), 36 bajtów

Wyjście jest truenieparzyste i falseparzyste. Zarówno dane wyjściowe, jak i wejściowe są sekwencjami.

(fn[l](map #(odd?(-(apply + l)%))l))
madstap
źródło
2

PHP, 50 bajtów

Wersje online

1 dla nieparzystych, 0 dla parzystych

Dane wyjściowe jako ciąg oddzielony _

<?foreach($_GET as$v)echo array_sum($_GET)-$v&1,_;

PHP, 72 bajty

Dane wyjściowe jako użycie tablicy array_map

<?print_r(array_map(function($v){return array_sum($_GET)-$v&1;},$_GET));
Jörg Hülsermann
źródło
1
Możesz upuścić, ?:0to nic nie robi. foreach($_GET as$v)echo array_sum($_GET)-$v&1,_;
Christoph
2

C, 68 62 bajtów

i;s;f(c,l)int*l;{while(i<c)s+=l[i++];while(i)l[--i]=s-l[i]&1;}

1 dla nieparzystych, 0 dla parzystych

Szczegółowe Wypróbuj online

f(int c, int * l)
{
    int i = 0, s = 0;

    while(i < c)
    {
        s = s + l[i];
        i = i + 1;
    }

    // assert(i == c)

    while(i > 0)
    {
        i = i - 1;
        l[i] = s - l[i]&1;
    }
}
Khaled.K
źródło
2

Siatkówka , 40 38 bajtów

\d+
¶$` $'
^¶

\d+
$*
+` |11

%M`1
¶
 

Wypróbuj online! Wyjścia 1 dla nieparzystych i 0 dla parzystych. Objaśnienie: Pierwsze dwa wiersze duplikują dane wejściowe jeden raz dla każdej liczby na wejściu, ale bez samego elementu. To tworzy dodatkową pustą linię, która jest następnie usuwana. Dane wejściowe są następnie konwertowane z dziesiętnej na unarną, spacje są usuwane, a parzystość obliczana. Nawet parzystość jest następnie konwertowana na zero, a wyniki ponownie łączone w jedną linię. Edycja: Zapisano 2 bajty dzięki @FryAmTheEggman. Wypróbowałem kilka innych wersji, które są koncepcyjnie bardziej przyjemne, ale do wyrażenia wymagają o wiele za dużo bajtów:

\d\B

T`2468O`00001
T`d`10`^([^1]*1[^1]*1)*[^1]*1[^1]*$

Zmienia wszystkie dane wejściowe na ich parzystość, a następnie odwraca wszystkie ich parytety, jeśli suma ma nieparzystą parzystość.

\d+
$*
^.*
$&¶$&
 (?=.*$)

11

\B
0
T`d`10`.*¶1
¶0

Sumuje duplikat danych wejściowych, a następnie przyjmuje parzystość wszystkiego, a następnie odwraca parzystości, jeśli suma jest nieparzysta, a następnie usuwa sumę ponownie.

Neil
źródło
Próbowałem tego, co mi przyszło do głowy, i otrzymałem nieco krótsze rozwiązanie , choć nadal uważam, że nie jest to optymalne. Szczególnie nie podoba mi się, jak radzę sobie z dodatkowym zerem, które dostaję na końcu.
FryAmTheEggman
@FryAmTheEggman Twoje oszczędności pochodzą z mniej widocznego sposobu przekształcania twoich ;pleców w spacje. Jeśli umieścisz ;na początku, możesz zapisać bajt, usuwając go natychmiast, a nie po konwersji na 0.
Neil
Właściwie, patrząc ponownie, dlaczego twój ostatni etap nie zastępuje znaku nowej linii spacjami? Czy nie zaoszczędziłoby to 2 bajtów?
FryAmTheEggman
@FryAmTheEggman Tak; Myślę, że pierwotnie miałem więcej niż jeden zamiennik do wykonania w poprzedniej iteracji.
Neil
1

k, 9 bajtów

{2!x-+/x}

Wyjście jest 1na odd, a 0na parzyste. Wypróbuj online.

Przekształcony w pseudokod, będzie to:

for number in x:
    yield (number - sum(x)) % 2
zgrep
źródło
1

Brain-Flak , 94 68 66 bajtów

({({}<>)<>})<>{<>(({})<({}<>{}<>(())){({}[()]<([{}])>)}{}>)<>}<>{}

Wypróbuj online!

To wydaje się trochę za długie na zadanie. Może to być wygodniejszy sposób.

Wyjaśnienie

Najpierw obliczamy sumę stosu za pomocą:

({({}<>)<>})

Przechodzimy przez cały stos, dodając ten wynik do każdego elementu i określając pary

<>{<>(({})<({}<>{}<>(())){({}[()]<([{}])>)}{}>)<>}<>{}

Wykorzystuje całkiem fajny algorytm mod 2, który wymyśliłem do tego wyzwania.

({}(())){({}[()]<([{}]())>)}{}

Spycha to 1 poniżej dekretu wejściowego, aż sygnał wejściowy osiągnie zero za każdym razem, gdy wykonujemy 1-n1, który umieściliśmy wcześniej, a następnie usuwa dane wejściowe.

Kreator pszenicy
źródło
W końcu możesz zmodyfikować 2. Nie musisz modyfikować sumy 2.
Leaky Nun
@LeakyNun Thanks! Właśnie to zrozumiałem i naprawiłem.
Kreator pszenicy
1

Wise , 54 52 bajtów

::^:??[:!^:?^:!^:?^?]|!::^??[!:?^:><^!:?^:!^:?^?]!&|

Wypróbuj online!

Wyjaśnienie

Ten kod byłby o wiele krótszy, gdyby nie zajęło tylu bajtów zamiana dwóch górnych elementów. Obecny rekord to

:?^:!^:?^!

To niestety stanowi większość kodu.


Najpierw bierzemy sumę XOR stosu

::^:??[:!^:?^:!^:?^?]|!

Następnie XOR to z każdym elementem i elementem z ostatnim bitem zerowanym

::^??[!:?^:><^!:?^:!^:?^?]!&|
Kreator pszenicy
źródło
1

AWK , 64 bajty

{for(i=0;++i<=NF;print s[i]%2)for(j=0;++j<=NF;)if(i!=j)s[i]+=$j}

Wypróbuj online!

Wyprowadza 0a 1dla liczb parzystych i dla liczb nieparzystych oddzielonych znakami nowej linii. Jedynym, nawet nieco nieszablonowym, pomysłem było umieszczenie printpolecenia wewnątrzfor kroku „przyrostu”. Próbowałem kilku „sprytnych” sposobów drukowania, ale nie oszczędzały bajtów.

Tylko na chichot, jeśli nie chcesz nowych linii:

{for(i=0;++i<=NF;m=m,s[i]%2)for(j=0;++j<=NF;)if(i!=j)s[i]+=$j}1

który ma taką samą liczbę bajtów jak powyżej, ale jest nieco bardziej rozwarty.

Robert Benson
źródło
1

Szybki - 55 bajtów

Wreszcie bije C! Również 0 dla parzystej, 1 dla nieparzystej

func g(a:[Int]){for i in a{print((a.reduce(0,+)-i)%2)}}

Funkcja z użyciem: g(a: [1,2,3,2,1] // => 0 1 0 1 0

Sprawdź to!

Pan Xcoder
źródło
Nie zna Swift, ale w wielu językach można zastąpić (x-y)%2zx-y&1
Cyoce
@Cyoce Dla mnie po testach to nie działa. Operacje bitowe nie są mocną stroną Swift
Mr. Xcoder
1

Aksjomat, 45 bajtów

f(a)==[(reduce(+,a)-a.j)rem 2 for j in 1..#a]

brak sprawdzania typu danych wejściowych, możliwe przeliczenie sumy „a” każdego elementu… testy

(27) -> [[a,f(a)] for a in [[1,2,3,1], [1,2,3,2,1], [2,2], [100, 1001] ]]
   (27)
   [[[1,2,3,1],[0,1,0,0]], [[1,2,3,2,1],[0,1,0,1,0]], [[2,2],[0,0]],
    [[100,1001],[1,0]]]
RosLuP
źródło