title
Description
Body
На висах спрашивал, что-то ответа не получил! а еще некоторые себя программистами считают))
Гемор, думаю ты должен это знать Собственно сабж:
Нужно перевести десятичную дробь например(0,65), в двоичную систему счисления!
На примере дроби 0,75 все выходит просто:
0,75 *2 = 1,50 * 2 = 3,00 в итоге получаем 0,11 - получили единицу, и на этом останавливаемся!
а в примере 0,65 уже сложнее... тут мы получаем бесконечный цикл, который может продолжаться бесконечно!
Как понять что мы получили необходимую точность вычислений?
Добавлено спустя 9 минут 14 секунд:
т.е получается 0,65*2 = 1,30 * 2 = 0,60 * 2 = 1,22 * 2 = 0,44 * 2 = 0,88 и тут начинается цикл! т.е
1,76 -> 1,52 -> 1,04 -> 0,08 -> 0,16 -> 0,32 -> 0,64 -> 1,28 -> 0,46 -> 0,72 -> 1,44 и опять получается 0,88
Неактивен
и еще из десятичной в двоичную что - то не получается!
101101 = 1*2^0 + 0*2^1 + 1*2^2 + 1*2^3 + 0*2^4 + 1*2^5 = 0 + 2 + 4 + 8 + 32 = 46
проверяем
46/2 = 23 -> 46 - 46 = 0
23/2 = 11 -> 23 - 22 = 1
11/2 = 5 -> 11 - 10 = 1
5/2 = 2 -> 5 - 4 = 1
2/2 = 1 -> 2 - 2 = 0
1
и получается 101110 совсем другое число! и как так получилось что на 1 больше?
Неактивен
Nu3oN написал:
и еще из десятичной в двоичную что - то не получается!
101101 = 1*2^0 + 0*2^1 + 1*2^2 + 1*2^3 + 0*2^4 + 1*2^5 = 0 + 2 + 4 + 8 + 32 = 46
проверяем
46/2 = 23 -> 46 - 46 = 0
23/2 = 11 -> 23 - 22 = 1
11/2 = 5 -> 11 - 10 = 1
5/2 = 2 -> 5 - 4 = 1
2/2 = 1 -> 2 - 2 = 0
1
и получается 101110 совсем другое число! и как так получилось что на 1 больше?
С этим разобрался, мой косяк!
тут идет
101101 = 1*2^0 + 0*2^1 + 1*2^2 + 1*2^3 + 0*2^4 + 1*2^5 = 1 + 0 + 4 + 8 + 32 = 45
Неактивен