인프런 커뮤니티 질문&답변
비트연산자
해결된 질문
작성
·
28
0

비트 연산을 하면 답이 15가 되어야 하는거 아닌가요?
5의 2진수는 0101이고 10의 2진수는 1010이므로
xor연산자 하면 1111즉 15가 되어야하는데 왜 이전 값을 대입 하나요..? a랑 b를 xor한 값대입하라고 적혀있는데 이유 알 수 있을 까요?
답변 2
0
안녕하세요, 비트연산에 대해서는 아래 인프런 AI 인턴 내용을 보시면 더 잘 나와있습니다.
변수는 위에서 할당을 하고 나서 아래에서는 위에서 할당받은 변수를 그대로 가져옵니다.
그래서 위에서 완성된 변수를 아래로 똑같이 진행하시면 됩니다.
저렇게 값이 교환된다는 것만 알고 계시면 됩니다.
비트 연산자는 원리 정도만 알고 가시면 크게 문제가 되지는 않습니다.
0
안녕하세요, 인프런 AI 인턴입니다. jongbin7245님.
비트 연산자 사용 방법에 대한 궁금증에 대해 설명드리겠습니다. XOR 연산자는 두 비트가 다를 때 1을 반환하는 연산자로, 두 값을 교환하는 데도 활용됩니다.
주어진 코드에서 XOR를 사용하여 a와 b의 값을 교환하는 방법은 다음과 같습니다:
Initial State:
a = 5(Binary:0101)
b = 10(Binary:1010)
First XOR Operation:
a = a ^ b- Result:
a = 0101 ^ 1010 = 1111(Binary) = 15 (Decimal)
- Result:
Second XOR Operation:
b = a ^ b
Here,ais already updated to1111.- Result:
b = 1111 ^ 1010 = 0101(This recovers the originalavalue, i.e., 5)
- Result:
Third XOR Operation:
a = a ^ b- Result:
a = 1111 ^ 0101 = 1010(This recovers the originalbvalue, i.e., 10)
- Result:
결과적으로 a와 b의 값이 서로 교환됩니다. XOR 연산을 세 번 사용하여 두 변수의 값을 교환하는 방식입니다. 그래픽이나 코드에서 a와 b의 값이 교환된 후 최종적으로 a = 10과 b = 5가 되는 것을 확인할 수 있습니다.
이와 같이 XOR 연산을 이용하면 추가적인 메모리 할당 없이 직접 두 변수의 값을 교환할 수 있습니다.
관련하여 자세한 설명과 예제를 포함한 기존 질문이 있는 링크를 제공하니 참고하시기 바랍니다:
- 쉬프트연산 - 이 링크에서는 비트 연산자의 사용법을 더 많은 예제로 설명하고 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





