인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

asd님의 프로필 이미지

작성한 질문수

독하게 시작하는 C 프로그래밍

보수에 대해 이해가 안됩니다.

해결된 질문

작성

·

107

·

수정됨

0

선생님 안녕하세요! 수업 중 강의를 듣다가 보수에 대한 이해가 되지 않아 질문드립니다.

보수란 보충해주는 수 라고 알고있습니다.

강의에서 1의 보수는 어떤 수에 대해서 더해서 1이 되는 수라고 말씀하셨고 1의 보수를 구하는 예시로 2진수 1100에 대한 1의 보수를 구하는 방법으로 NOT연산을 하여 0011을 만들 수 있었습니다.
그럼 1100에 대한 1의 보수가 0011이라고 이해했습니다.

즉 1100 + 0011을 하면 10진수 1또는 2진수 0001 이 나와야한다고 이해했습니다.

그러나 실상은 2진수 111110진수로는 15가 되어버립니다. 분명 1의 보수를 구한거면 더해서 1되는 수라고 말씀하셨는데 15가 계산이 되는데 제가 어느 부분에 대한 개념을 못잡고 있는걸까요?

답변 2

0

널널한 개발자님의 프로필 이미지
널널한 개발자
지식공유자

컴퓨터의 뺄셈은 2의 보수를 더하는 방식으로 구현됩니다. 2의 보수는 1의 보수에 1을 더한 수로 정의 할 수 있습니다. 따라서 1100 + (0011 + 0001)로 생각해야 바른 결과를 얻을 수 있습니다. 참고하시기 바랍니다. 😄

0

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다. 송동규님!

질문해주신 보수 연산의 개념에 대해 설명드리겠습니다.

보수는 컴퓨터 과학에서 숫자 연산에 많이 사용되는데, 특히 뺄셈을 덧셈으로 변환할 때 중요하게 다뤄집니다.

1의 보수2의 보수가 있는데요:

  1. 1의 보수: 어떤 이진수에서 각 비트를 뒤집어(0을 1로, 1을 0으로) 만드는 것을 말합니다. 예를 들어, 이진수 1100의 1의 보수는 0011입니다. 그러나 1의 보수를 더해서 1이 되는 것은 아니라, 모든 자리의 비트를 반전시켰다는 의미입니다. 즉, 더했을 때 각 자리에서 올림(캐리)이 발생하지 않는 경우 전체가 1이 되는 것이 아니라는 점을 이해하셔야 합니다.

  2. 2의 보수: 1의 보수에서 1을 더한 것입니다. 예로 1100의 1의 보수는 0011, 여기에 1을 더하면 0100이 됩니다. 2의 보수가 실질적인 연산에서 사용되어, 이를 통해 덧셈으로 뺄셈을 수행할 수 있습니다. 즉, A - B는 A + (~B) + 1로 표현할 수 있게 되는 것이죠.

보수가 포함된 계산 예시로, 1100에 1의 보수를 더했을 때 기대한 결과가 아니라 1111이 나오는 것은 1의 보수가 가지고 있는 비트 반전의 결과물 때문입니다. 이때 발생한 날 것 같은 결과는 화면 상 출력일 뿐, 이 연산이 실제로 수학적 의미(덧셈)을 만족하지는 않습니다. 따라서, 이를 보정하기 위해 우리는 2의 보수를 사용하게 되며 이는 실제 프로그래밍에서 덧셈 및 뺄셈 연산을 원활하게 수행하는데 매우 유용합니다.

이에 대해 더 알고 싶으시면 다음의 유사 질문들을 참고하실 수 있습니다:

  1. 비트연산자 뺄셈 구현에서 질문이 있습니다.
  2. 보수와 수의 음수는 같은 게 아닌가요?

위 링크를 참고하시면, 보수 개념에 대한 이해가 더 명확해질 것입니다.

저는 송동규님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

asd님의 프로필 이미지
asd
질문자

널널한 개발자님 도와주세요!! 이해가 안됩니다.

asd님의 프로필 이미지

작성한 질문수

질문하기