- cross-posted to:
- bumba@boomer.casino
- programmerhumor@lemmy.ml
- cross-posted to:
- bumba@boomer.casino
- programmerhumor@lemmy.ml
Yay or nay, memes should be allowed in !python@programming.dev ?
Yay or nay, memes should be allowed in !python@programming.dev ?
xor has the property x ^ x = 0, and x ^ 0 = x. So, x ^ x ^ y = y
a' = a ^ b b' = b ^ a' = b ^ (a ^ b) = a a'' = (a ^ b) ^ a = b
This is pretty clever, I’ve never seen this for a swap.
Couldn’t have explained it better myself. I don’t remember where exactly I first read about this trick, but it’s mainly useful in C or Assembly, as you don’t have to resort to using a third variable/register.