Care sunt pașii pentru scrierea numărului binar cu semn în reprezentarea în complement față de unu (1) ca întreg în sistem zecimal (în baza zece)?
1. Este acesta un număr pozitiv sau negativ?
1110 0000 1110 1101 0101 1110 0011 0010 este reprezentarea binară a unui întreg negativ, pe 32 biți (4 Octeți).
- Într-un număr binar cu semn în reprezentarea în complement față de unu, primul bit (cel mai din stânga) indică semnul, 1 = negativ, 0 = pozitiv.
2. Obține reprezentarea binară a numărului pozitiv.
* Parcurge acest pas doar dacă numărul e negativ *
Înlocuiește biții setați pe 1 cu 0 și biții de pe 0 cu 1 în numărul binar cu semn scris în reprezentarea în complement față de unu:
!(1110 0000 1110 1101 0101 1110 0011 0010) = 0001 1111 0001 0010 1010 0001 1100 1101
3. Mapează digiții numărului binar fără semn cu puterile lui 2 corespunzătoare ordinului de mărime:
231
0 230
0 229
0 228
1 227
1 226
1 225
1 224
1 223
0 222
0 221
0 220
1 219
0 218
0 217
1 216
0 215
1 214
0 213
1 212
0 211
0 210
0 29
0 28
1 27
1 26
1 25
0 24
0 23
1 22
1 21
0 20
1
4. Înmulțește fiecare bit cu puterea lui 2 corespunzătoare, apoi însumează termenii.
0001 1111 0001 0010 1010 0001 1100 1101(2) =
(0 × 231 + 0 × 230 + 0 × 229 + 1 × 228 + 1 × 227 + 1 × 226 + 1 × 225 + 1 × 224 + 0 × 223 + 0 × 222 + 0 × 221 + 1 × 220 + 0 × 219 + 0 × 218 + 1 × 217 + 0 × 216 + 1 × 215 + 0 × 214 + 1 × 213 + 0 × 212 + 0 × 211 + 0 × 210 + 0 × 29 + 1 × 28 + 1 × 27 + 1 × 26 + 0 × 25 + 0 × 24 + 1 × 23 + 1 × 22 + 0 × 21 + 1 × 20)(10) =
(0 + 0 + 0 + 268 435 456 + 134 217 728 + 67 108 864 + 33 554 432 + 16 777 216 + 0 + 0 + 0 + 1 048 576 + 0 + 0 + 131 072 + 0 + 32 768 + 0 + 8 192 + 0 + 0 + 0 + 0 + 256 + 128 + 64 + 0 + 0 + 8 + 4 + 0 + 1)(10) =
(268 435 456 + 134 217 728 + 67 108 864 + 33 554 432 + 16 777 216 + 1 048 576 + 131 072 + 32 768 + 8 192 + 256 + 128 + 64 + 8 + 4 + 1)(10) =
521 314 765(10)
5. Dacă e nevoie, ajustează semnul numărului întreg în funcție de primul digit (cel mai din stânga) al numărului binar cu semn: