inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

비트마스킹 개념 #2-4. 비트연산자의 기초(^, ~) XOR, Ones' complement

~연산자 질문있습니다 :)

187

한유태

작성한 질문수 79

0

안녕하세요 선생님 🙂

~연산자 부분에서 이해가 되지 않는 부분이 있어서 질문드립니다.

 

양의 정수와 음의 정수 상관없이 ~연산자를 사용하면 -(value + 1)이 되는 것을 확인했습니다. 이건 1의 보수 값인가요 2의 보수 값인가요?

c++ 코딩-테스트

답변 2

1

큰돌

안녕하세요 유태님 ㅎㅎ

예를 들어 양수 5에 대해 ~5를 계산해보면:

  • 5의 이진수는 0000 0101입니다.

  • ~5는 이 비트의 반전이므로 1111 1010이 됩니다. (이는 1의 보수입니다.)

  • 1111 1010은 2의 보수 표기법에서 -6을 나타냅니다.

결과적으로 다음과 같이 되는 것이죠.

~5 = -6 = -(5 + 1)

 

즉, ~ 연산자는 1의 보수 연산을 수행하지만, 그 결과는 2의 보수 표기법에 따라 해석됩니다.

 


또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림. 


0

한유태

답변 감사합니다 🙂 1의 보수 연산을 수행하여 2의 보수 표기법으로 출력된다는 말씀이신거죠?

0

귀여운 수달

어떤 수(a)의 음수는 비트를 반전 시킨 후 1을 더한 수다.
-a = ~a + 1

그렇다면 어떤 수(a)의 반전은 어떤 수(a)의 음에 1을 뺀 값이다.
~a = -a - 1
즉, 어떤 수(a)의 반전은 어떤 수(a)에 1을 더한 수의 음이다.
~a = -(a + 1)

3-D 관련 질문

0

19

2

코살구 회원가입 문의

0

21

2

코살구 로그인 문제

0

42

2

3-A 문제 풀이 관련 질문

0

42

2

2-O 질문 있습니다

0

35

2

2-T 문제에 관한 질문

0

36

2

코딩 살구 클럽 접속 및 사용방법 문의

0

51

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

63

2

코딩살구클럽 로그인문제

0

68

3

코딩 살구 클럽 로그인 문제

0

75

2

2-J 채점관련 질문

0

64

3

코딩 살구 클럽 Python 지원 가능 여부

0

75

1

살구클럽 아이디 없음 문제

0

74

1

1-O 코딩살구클럽 채점관련 질문

0

57

2

히든 테스트 케이스가 사라졌습니다

0

55

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

73

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

65

2

1-H 문제 채점하기 오류

0

58

3

코딩살구클럽 2주차 2-L 문제 채점하기 오류

0

52

2

살구 클럽 채점 관련 문의

0

62

2

코딩 살구 클럽 실전 세션

0

57

2

코딩살구클럽 채점 관련 질문

0

50

2

코딩살구클럽 컴파일에러

0

79

2

5-B

0

49

2