비트연산자

비트 연산을 하면 답이 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 연산을 이용하면 추가적인 메모리 할당 없이 직접 두 변수의 값을 교환할 수 있습니다.
관련하여 자세한 설명과 예제를 포함한 기존 질문이 있는 링크를 제공하니 참고하시기 바랍니다:
- 쉬프트연산 - 이 링크에서는 비트 연산자의 사용법을 더 많은 예제로 설명하고 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)
0
57
2
26년 1회 실기 해설 강의
0
78
2
53번 4-1 자료 오류 있는 것 같습니다.
0
76
2
7번문제
0
62
2
C언어 변형문제 9번문제 Pdf 수정요청
0
51
2
메서드 오버드라드
0
55
2
실수
0
46
1
공부 우선순위 우선강의 알려주세요
0
93
1
생성자 호출순서 강의 10번 문제 30분대 질문입니다
0
52
2
25년 2회 기출 5:40 질문입니다.
0
43
2
모의고사1회 3번 파이썬문제
0
76
2
C언어 출제변형 6번 문제
0
50
2
c언어 출제변형 강의 질문
0
32
2
28:40
0
34
2
C : 언어 배열과 문자열 수업자료
0
31
2
파이썬 리스트, 딕셔너리 질문
0
43
2
모의고사 관련 질문 건
1
69
3
자료 내용 오류
0
65
2
정적 변수, 정적 메서드(static) v2
0
51
2
v1.2 와 v0.91 PDF
0
104
1
업캐스팅 (부모형태, 자식생성자)
0
53
2
정보처리산업기사 준비중입니다.
0
74
2
실기 D -6
0
105
2
(기출) 2024년 2회 기출문제 - 이론 포함 22분32초 질문입니다
0
63
3





