Convert -1 000 000 000 039 to a Signed Binary in Two's (2's) Complement Representation
How to convert decimal number -1 000 000 000 039(10) to a signed binary in two's (2's) complement representation
What are the steps to convert decimal number
-1 000 000 000 039 to a signed binary in two's (2's) complement representation?
- A signed integer, written in base ten, or a decimal system number, is a number written using the digits 0 through 9 and the sign, which can be positive (+) or negative (-). If positive, the sign is usually not written. A number written in base two, or binary, is a number written using only the digits 0 and 1.
1. Start with the positive version of the number:
|-1 000 000 000 039| = 1 000 000 000 039
2. Divide the number repeatedly by 2:
Keep track of each remainder.
We stop when we get a quotient that is equal to zero.
- division = quotient + remainder;
- 1 000 000 000 039 ÷ 2 = 500 000 000 019 + 1;
- 500 000 000 019 ÷ 2 = 250 000 000 009 + 1;
- 250 000 000 009 ÷ 2 = 125 000 000 004 + 1;
- 125 000 000 004 ÷ 2 = 62 500 000 002 + 0;
- 62 500 000 002 ÷ 2 = 31 250 000 001 + 0;
- 31 250 000 001 ÷ 2 = 15 625 000 000 + 1;
- 15 625 000 000 ÷ 2 = 7 812 500 000 + 0;
- 7 812 500 000 ÷ 2 = 3 906 250 000 + 0;
- 3 906 250 000 ÷ 2 = 1 953 125 000 + 0;
- 1 953 125 000 ÷ 2 = 976 562 500 + 0;
- 976 562 500 ÷ 2 = 488 281 250 + 0;
- 488 281 250 ÷ 2 = 244 140 625 + 0;
- 244 140 625 ÷ 2 = 122 070 312 + 1;
- 122 070 312 ÷ 2 = 61 035 156 + 0;
- 61 035 156 ÷ 2 = 30 517 578 + 0;
- 30 517 578 ÷ 2 = 15 258 789 + 0;
- 15 258 789 ÷ 2 = 7 629 394 + 1;
- 7 629 394 ÷ 2 = 3 814 697 + 0;
- 3 814 697 ÷ 2 = 1 907 348 + 1;
- 1 907 348 ÷ 2 = 953 674 + 0;
- 953 674 ÷ 2 = 476 837 + 0;
- 476 837 ÷ 2 = 238 418 + 1;
- 238 418 ÷ 2 = 119 209 + 0;
- 119 209 ÷ 2 = 59 604 + 1;
- 59 604 ÷ 2 = 29 802 + 0;
- 29 802 ÷ 2 = 14 901 + 0;
- 14 901 ÷ 2 = 7 450 + 1;
- 7 450 ÷ 2 = 3 725 + 0;
- 3 725 ÷ 2 = 1 862 + 1;
- 1 862 ÷ 2 = 931 + 0;
- 931 ÷ 2 = 465 + 1;
- 465 ÷ 2 = 232 + 1;
- 232 ÷ 2 = 116 + 0;
- 116 ÷ 2 = 58 + 0;
- 58 ÷ 2 = 29 + 0;
- 29 ÷ 2 = 14 + 1;
- 14 ÷ 2 = 7 + 0;
- 7 ÷ 2 = 3 + 1;
- 3 ÷ 2 = 1 + 1;
- 1 ÷ 2 = 0 + 1;
3. Construct the base 2 representation of the positive number:
Take all the remainders starting from the bottom of the list constructed above.
1 000 000 000 039(10) = 1110 1000 1101 0100 1010 0101 0001 0000 0010 0111(2)
4. Determine the signed binary number bit length:
The base 2 number's actual length, in bits: 40.
- A signed binary's bit length must be equal to a power of 2, as of:
- 21 = 2; 22 = 4; 23 = 8; 24 = 16; 25 = 32; 26 = 64; ...
- The first bit (the leftmost) indicates the sign:
- 0 = positive integer number, 1 = negative integer number
The least number that is:
1) a power of 2
2) and is larger than the actual length, 40,
3) so that the first bit (leftmost) could be zero
(we deal with a positive number at this moment)
=== is: 64.
5. Get the positive binary computer representation on 64 bits (8 Bytes):
If needed, add extra 0s in front (to the left) of the base 2 number, up to the required length, 64.
1 000 000 000 039(10) = 0000 0000 0000 0000 0000 0000 1110 1000 1101 0100 1010 0101 0001 0000 0010 0111
6. Get the negative integer number representation. Part 1:
- To write the negative integer number on 64 bits (8 Bytes), as a signed binary in one's complement representation, replace all the bits on 0 with 1s and all the bits set on 1 with 0s.
Reverse the digits, flip the digits:
Replace the bits set on 0 with 1s and the bits set on 1 with 0s.
!(0000 0000 0000 0000 0000 0000 1110 1000 1101 0100 1010 0101 0001 0000 0010 0111)
= 1111 1111 1111 1111 1111 1111 0001 0111 0010 1011 0101 1010 1110 1111 1101 1000
7. Get the negative integer number representation. Part 2:
- To write the negative integer number on 64 bits (8 Bytes), as a signed binary in two's complement representation, add 1 to the number calculated above 1111 1111 1111 1111 1111 1111 0001 0111 0010 1011 0101 1010 1110 1111 1101 1000 (to the signed binary in one's complement representation).
Binary addition carries on a value of 2:
- 0 + 0 = 0
- 0 + 1 = 1
- 1 + 1 = 10
- 1 + 10 = 11
- 1 + 11 = 100
Add 1 to the number calculated above
(to the signed binary number in one's complement representation):
-1 000 000 000 039 =
1111 1111 1111 1111 1111 1111 0001 0111 0010 1011 0101 1010 1110 1111 1101 1000 + 1
Decimal Number -1 000 000 000 039(10) converted to signed binary in two's complement representation:
-1 000 000 000 039(10) = 1111 1111 1111 1111 1111 1111 0001 0111 0010 1011 0101 1010 1110 1111 1101 1001
Spaces were used to group digits: for binary, by 4, for decimal, by 3.