Convert -3 352 949 406 to a Signed Binary in Two's (2's) Complement Representation
How to convert decimal number -3 352 949 406(10) to a signed binary in two's (2's) complement representation
What are the steps to convert decimal number
-3 352 949 406 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:
|-3 352 949 406| = 3 352 949 406
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;
- 3 352 949 406 ÷ 2 = 1 676 474 703 + 0;
- 1 676 474 703 ÷ 2 = 838 237 351 + 1;
- 838 237 351 ÷ 2 = 419 118 675 + 1;
- 419 118 675 ÷ 2 = 209 559 337 + 1;
- 209 559 337 ÷ 2 = 104 779 668 + 1;
- 104 779 668 ÷ 2 = 52 389 834 + 0;
- 52 389 834 ÷ 2 = 26 194 917 + 0;
- 26 194 917 ÷ 2 = 13 097 458 + 1;
- 13 097 458 ÷ 2 = 6 548 729 + 0;
- 6 548 729 ÷ 2 = 3 274 364 + 1;
- 3 274 364 ÷ 2 = 1 637 182 + 0;
- 1 637 182 ÷ 2 = 818 591 + 0;
- 818 591 ÷ 2 = 409 295 + 1;
- 409 295 ÷ 2 = 204 647 + 1;
- 204 647 ÷ 2 = 102 323 + 1;
- 102 323 ÷ 2 = 51 161 + 1;
- 51 161 ÷ 2 = 25 580 + 1;
- 25 580 ÷ 2 = 12 790 + 0;
- 12 790 ÷ 2 = 6 395 + 0;
- 6 395 ÷ 2 = 3 197 + 1;
- 3 197 ÷ 2 = 1 598 + 1;
- 1 598 ÷ 2 = 799 + 0;
- 799 ÷ 2 = 399 + 1;
- 399 ÷ 2 = 199 + 1;
- 199 ÷ 2 = 99 + 1;
- 99 ÷ 2 = 49 + 1;
- 49 ÷ 2 = 24 + 1;
- 24 ÷ 2 = 12 + 0;
- 12 ÷ 2 = 6 + 0;
- 6 ÷ 2 = 3 + 0;
- 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.
3 352 949 406(10) = 1100 0111 1101 1001 1111 0010 1001 1110(2)
4. Determine the signed binary number bit length:
The base 2 number's actual length, in bits: 32.
- 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, 32,
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.
3 352 949 406(10) = 0000 0000 0000 0000 0000 0000 0000 0000 1100 0111 1101 1001 1111 0010 1001 1110
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 0000 0000 1100 0111 1101 1001 1111 0010 1001 1110)
= 1111 1111 1111 1111 1111 1111 1111 1111 0011 1000 0010 0110 0000 1101 0110 0001
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 1111 1111 0011 1000 0010 0110 0000 1101 0110 0001 (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):
-3 352 949 406 =
1111 1111 1111 1111 1111 1111 1111 1111 0011 1000 0010 0110 0000 1101 0110 0001 + 1
Decimal Number -3 352 949 406(10) converted to signed binary in two's complement representation:
-3 352 949 406(10) = 1111 1111 1111 1111 1111 1111 1111 1111 0011 1000 0010 0110 0000 1101 0110 0010
Spaces were used to group digits: for binary, by 4, for decimal, by 3.