Convert -135 291 469 828 to a Signed Binary in Two's (2's) Complement Representation
How to convert decimal number -135 291 469 828(10) to a signed binary in two's (2's) complement representation
What are the steps to convert decimal number
-135 291 469 828 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:
|-135 291 469 828| = 135 291 469 828
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;
- 135 291 469 828 ÷ 2 = 67 645 734 914 + 0;
- 67 645 734 914 ÷ 2 = 33 822 867 457 + 0;
- 33 822 867 457 ÷ 2 = 16 911 433 728 + 1;
- 16 911 433 728 ÷ 2 = 8 455 716 864 + 0;
- 8 455 716 864 ÷ 2 = 4 227 858 432 + 0;
- 4 227 858 432 ÷ 2 = 2 113 929 216 + 0;
- 2 113 929 216 ÷ 2 = 1 056 964 608 + 0;
- 1 056 964 608 ÷ 2 = 528 482 304 + 0;
- 528 482 304 ÷ 2 = 264 241 152 + 0;
- 264 241 152 ÷ 2 = 132 120 576 + 0;
- 132 120 576 ÷ 2 = 66 060 288 + 0;
- 66 060 288 ÷ 2 = 33 030 144 + 0;
- 33 030 144 ÷ 2 = 16 515 072 + 0;
- 16 515 072 ÷ 2 = 8 257 536 + 0;
- 8 257 536 ÷ 2 = 4 128 768 + 0;
- 4 128 768 ÷ 2 = 2 064 384 + 0;
- 2 064 384 ÷ 2 = 1 032 192 + 0;
- 1 032 192 ÷ 2 = 516 096 + 0;
- 516 096 ÷ 2 = 258 048 + 0;
- 258 048 ÷ 2 = 129 024 + 0;
- 129 024 ÷ 2 = 64 512 + 0;
- 64 512 ÷ 2 = 32 256 + 0;
- 32 256 ÷ 2 = 16 128 + 0;
- 16 128 ÷ 2 = 8 064 + 0;
- 8 064 ÷ 2 = 4 032 + 0;
- 4 032 ÷ 2 = 2 016 + 0;
- 2 016 ÷ 2 = 1 008 + 0;
- 1 008 ÷ 2 = 504 + 0;
- 504 ÷ 2 = 252 + 0;
- 252 ÷ 2 = 126 + 0;
- 126 ÷ 2 = 63 + 0;
- 63 ÷ 2 = 31 + 1;
- 31 ÷ 2 = 15 + 1;
- 15 ÷ 2 = 7 + 1;
- 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.
135 291 469 828(10) = 1 1111 1000 0000 0000 0000 0000 0000 0000 0100(2)
4. Determine the signed binary number bit length:
The base 2 number's actual length, in bits: 37.
- 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, 37,
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.
135 291 469 828(10) = 0000 0000 0000 0000 0000 0000 0001 1111 1000 0000 0000 0000 0000 0000 0000 0100
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 0001 1111 1000 0000 0000 0000 0000 0000 0000 0100)
= 1111 1111 1111 1111 1111 1111 1110 0000 0111 1111 1111 1111 1111 1111 1111 1011
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 1110 0000 0111 1111 1111 1111 1111 1111 1111 1011 (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):
-135 291 469 828 =
1111 1111 1111 1111 1111 1111 1110 0000 0111 1111 1111 1111 1111 1111 1111 1011 + 1
Decimal Number -135 291 469 828(10) converted to signed binary in two's complement representation:
-135 291 469 828(10) = 1111 1111 1111 1111 1111 1111 1110 0000 0111 1111 1111 1111 1111 1111 1111 1100
Spaces were used to group digits: for binary, by 4, for decimal, by 3.