inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

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

180

한유태

작성한 질문수 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)

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

10

0

교안 158페이지 문의드립니다

0

26

2

코딩살구클럽 관련 건의사항

0

60

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

28

1

진행 방법 질문드립니다!

0

58

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

60

2

2주차 개념#12 트리 순회

0

29

2

백준사이트가 종료된다고 합니다.

0

289

2

백준 서비스 종료

9

895

1

sk 하이닉스 코테 대비

0

370

2

3-G 최댓값 질문

0

51

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

83

2

3-I 코드 질문드립니다.

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

102

2

4-H 질문 있습니다 (코드 리뷰)

0

66

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

173

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

69

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

64

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

51

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

68

2

함수별 시간복잡도

0

74

2

3-h 질문입니다.

0

49

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

53

2