XOR 교체 알고리즘

Jmnote (토론 | 기여)님의 2014년 9월 30일 (화) 15:15 판 (→‎개요)

1 개요

XOR swap algorithm
XOR 교체 알고리즘, XOR 스왑 알고리즘
  • 임시 변수를 두지 않고, 두 변수를 배타적 논리합(XOR) 비트 연산을 이용하여 교체하는 알고리즘

 

2 코드 예제

C언어
void xor_swap(int *x, int *y)
{
    if (x != y) {
        *x ^= *y;
        *y ^= *x;
        *x ^= *y;
    }
}
if (*x != *y) *x ^= *y ^= *x ^= *y;
PHP
function xor_swap(&$a, &$b) {
    $a = $a ^ $b;
    $b = $a ^ $b;
    $a = $a ^ $b;
}
$a ^= $b ^= $a ^= $b;

3 같이 보기

4 참고 자료

문서 댓글 ({{ doc_comments.length }})
{{ comment.name }} {{ comment.created | snstime }}