Gå til innhold

Anbefalte innlegg

Videoannonse
Annonse

a ^ b, der a og b er binære siffer gir 1 bare når a og b er forskjellige:

1 ^ 1 = 0

1 ^ 0 = 1

0 ^ 1 = 1

0 ^ 0 = 0

 

^ "konverterer" det som skal sammenlignes til binært. Og sammenligner ett og ett par med bitter.

 

ex:

(show-xor 3 3)

11 xor 11 => 0

 

(show-xor 2 2)

10 xor 10 => 0

 

(show-xor 4 3)

100 xor 11 => 111

 

(11 er det samme som 011 .. og setter man 100 og 011 ved siden av hverandre ser man at hvert bittpar er forskjellige, og gir da 111)

 

En verdi "xorret" med seg selv gir da altid 0 (som GeirGrusom nevner indirekte i asm-koden).

 

Holder på å lære meg Lisp, trenger et "script-språk" som er litt mindre udugelig, heh, enn PHP; her er koden:

(defun show-xor (a b)
       (format t "~B xor ~B => ~B" a b (logxor a b)))

Endret av søppel
Lenke til kommentar

Opprett en konto eller logg inn for å kommentere

Du må være et medlem for å kunne skrive en kommentar

Opprett konto

Det er enkelt å melde seg inn for å starte en ny konto!

Start en konto

Logg inn

Har du allerede en konto? Logg inn her.

Logg inn nå
  • Hvem er aktive   0 medlemmer

    • Ingen innloggede medlemmer aktive
×
×
  • Opprett ny...