2의 보수로 표시된 음수의 절대값을 구할 때
먹딸기
2023.04.01
질문 제목 : 2의 보수로 표시된 음수의 절대값을 구할 때아래에 2의 보수로 표시된 음수의 절대값을 구하는 원리가 어떻게 되는지 궁금합니다.
질문 내용 :
예를 들어 -5를 8비트 2의 보수로 나타내면, 11111011 입니다.
-5를 다시 2의 보수로 취하면 5가 나오는데, 이 방법 말고 (최상위 비트가 나타내는 값) - (나머지 비트가 나타내는 값들의 합)
으로도 구할 수 있습니다. 2^7 - ( 2^6 + 2^5 + 2^4 + 2^3 + 2^1 + 2^0) = 128 - ( 64 + 32 + 16 + 8 + 2 + 1) = 5
종이에도 쓰면서 생각해봤는데, 어떻게 해서 이런 방법이 가능한 지 궁금합니다.
-
싴흐한세여니
그게 바로 2의 보수입니다. 2^n-1에다 빼면 1의 보수이고 2^n에다 빼면 2의 보수입니다.
1의 보수를 구하기 위해 뺄셈을 하는 것보다는 반전시키는 것이 간단하기 때문에 반전하는 것입니다.
일반적으로 컴퓨터에는 감산기가 없고 보수를 더하는 방식으로 뺄셈ㄹ 합니다. 그런데 보수를 구하기 위해 뺄셈을 한다는 것은 증명응 위한 증명이 되는 꼴입니다. 그래서 보수를 구할 때는 반전하는 것입니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692374 | 고수님들 댓글 마니부탁해요!!! (2) | 엄지 | 2025-04-22 |
2692343 | scnaf에 자꾸 선언을 참조하라는데;; (8) | 도래 | 2025-04-22 |
2692282 | 도스상에서 생성된 exe파일에 press~ 뜨게 하기 (4) | 회사원 | 2025-04-21 |
2692256 | scanf("%*c"); ㅠㅠ 고수님들 | 거북이 | 2025-04-21 |
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |