[JAVA] 2의 보수법 [음수의 2진 표현, 1의 보수+1]

2022. 1. 8. 18:05·◎ Java/Java☕
728x90


1. 음수의 2진 표현

n비트를 2진수로 표현하면 값의 개수는 총 2ⁿ개다. 4비트로 예를 들면, 4비트는 2⁴(=16) 개의 값을 표현할 수 있다. 이 값을 모두 '부호 없는 정수(0과 양수)'로 표현한다면 '0부터 15까지의 정수'를 나타낼 수 있다.

 

그럼 음수를 표현하려면 어떻게 해야 할까?

왼쪽의 첫 번째 비트(MSB)가
0이면 양수, 1이면 음수로 표현하자.

 

음수를 양수처럼 0처럼 순차적으로 채우게 되면 아래와 같은 문제가 발생한다.

 

1. 두 수를 더했을 때 2진수로 0이 되지 않는다.
2. 0이 두 개 존재(0, -0)
3. 2진수가 증가할 때 10진 음수는 감소

 

그러나, 아래와 같이 '2의 보수법'에 의해 음수를 배치하면 위의 언급한 문제들이 해결된다.

 

'2의 보수법'이 사용되기까지의 과정


2. 2의 보수법

어떤 수의 'n의 보수'는 더했을 때 n이 되는 수를 말한다.

* ex) 7의 '10의 보수'는 3, 3의 '10의 보수'는 7

 

즉, '2의 보수 관계'에 있는 두 2진수는 더하여 '(자리올림이 발생하고) 0이 되는 수'이다. 

 

0101 ← 10진수로 5
1011 ← 10진수로 -5
─────────
(1) 0000 ← 자리올림이 발생했으나 크기가 4 비트라서 버려짐

 

그럼 음수를 2진수로 표현하려면 어떻게 해야 할까?

2의 보수 = 1의 보수+1

 

0101 ← 10진수로 5
1010 ← 0101의 '1의 보수'
0001
────────────
1011 ← 10진수로 -5

* '1의 보수'는 0을 1로, 1을 0으로 바꾸는 것이다.


- 음수의 2진 표현을 구하는 방법

  (1) 음수의 절댓값을 2진수로 변환한다.
       : -5의 절댓값인 5를 2진수로 변환한다. 10진수 5를 2진수로 변환하면 '0101'이다.
  (2) (1)에서 구한 2진수의 1을 0으로, 0은 1로 바꾼다.(1의 보수 구하기)
       : '0101'이 '1010'이 된다.
  (3) (2)의 결과에 1을 더한다.(2의 보수 구하기, 1의 보수+1)
       : '1010'에 1을 더하면 '1011'이 되고, 이것이 -5의 2진 표현이다.

 

참고문헌 : 남궁성(2016), Java의 정석, 도우출판

728x90
'◎ Java/Java☕' 카테고리의 다른 글
  • [JAVA] 변수의 타입(2) [정수형 타입 byte, short, int, long, 오버플로우]
  • [JAVA] 변수의 타입(1) [논리형 타입 boolean, 문자형 타입 char]
  • [JAVA] 실수의 진법 변환 [10진 소수점수를 2진 소수점수로 변환]
  • [JAVA] 정수의 진법 변환 [10진수를 n진수로 변환, n진수를 10진수로 변환]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    html
    CSS
    Java
    코딩
    spring
    프로그래밍
    꿀팁
    javascript
    백준
    코딩 테스트
    Project
    Database
    BOJ
    jsp
    백준 티어
    SQL
    일상
    Oracle
    자바스크립트
    Error Note
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[JAVA] 2의 보수법 [음수의 2진 표현, 1의 보수+1]
상단으로

티스토리툴바