Перевод дробных чисел информатика

Перевод дробных чисел из одной системы счисления в другую

Перевод дробных чисел из одной системы счисления в другую

После того, как я сделал несколько калькуляторов для перевода между разными системами счисления — вот список от первой до последней версии, от самого простого к сложному: Перевод числа в другие системы счисления, Перевод из десятичной системы счисления, Перевод из одной системы счисления в другую — в комментариях стали периодически спрашивать — а что же, мол, дробные числа, как же их переводить? И когда спросили больше трех раз, я таки решил изучить этот вопрос.

Результатом стал калькулятор, который вы видите ниже, он умеет переводить и дробные числа в том числе. Как водится, для любознательных под калькулятором немного теории.

Перевод дробных чисел из одной системы счисления в другую

Теперь теория. Я, честно говоря, думал, что вопрос довольно сложный, но при ближайшем рассмотрении все оказалось проще простого. Надо было только держать в голове тот факт, что речь идет о позиционных системах счисления.
В чем тут суть? Рассмотрим на примере десятичного числа 6.125. Это дробное число в десятичной системе счисления представляется так:

Все просто, не так ли? Та же самая простота сохраняется и при записи дробного числа в любой другой системе счисления. Возьмем, например, горячо любимую каждым программистом двоичную систему и число, например, 110.001. Эта запись есть не что иное как

Да-да, число для примера было выбрано не просто так. То есть, 110.001 в двоичной системе есть 6.125 в десятичной. Принцип, я думаю, ясен.

Есть только одно но — все-таки из-за того, что здесь участвую дроби с разными знаменателями, не всегда одно и тоже число можно одинаково точно выразить в разных системах счисления. Что я имею в виду?

Возьмем, например, число . Отлично смотрится в десятичной системе счисления. Но вот если попробовать получить запись этого числа в двоичной системе счисления — будут проблемы. Попробуем, пока не устанем

Продолжать можно еще довольно долго, но уже сейчас видно, что 0.8 в десятичной системе это 0.11001100. (дальше очень много цифр) в двоичной. Если честно, то это периодическое число с перидом 1100, так что мы никогда не сможем выразить его точно в двоичной системе счисления. 110011001100. будет продолжаться до бесконечности.

Поэтому перевод дробного числа из одной системы счисления в другую чаще всего дает погрешность. Погрешность эта зависит от того, сколько разрядов мы используем для записи дробной части переведенного числа. Возьмем пример с числом 0.8 и используем для записи его двоичного представления шесть разрядов после запятой — 0.110011. Полученное число вовсе не 0.8, а 0.796875, разница при этом составляет 0.003125. Это и есть наша погрешность перевода десятичного числа 0.8 в двоичный вид при использовании шести разрядов после запятой.

Вес крайнего правого разряда (самого младшего разряда) называется разрешением (resolution) или точностью (precision), и определяет наименьшее неравное нулю число, которое может быть представлено данным числом разрядов. Для нашего примера это . При этом максимально возможная погрешность представления числа, как нетрудно сообразить, не превышает половины этого веса, или 0.0078125. Так что для 0.8 мы имеем еще и не самую плохую погрешность.

Источник

Перевод целых и дробных чисел из одной системы счисления в другую

Поскольку одно и то же число может быть записано в различных СС, то возможен перевод числа из одной системы в другую. Т.к. самая распространенная СС – десятичная, то необходимо рассмотреть алгоритмы перевода из десятичной системы в другую и обратно.

1. Алгоритм перевода из десятичной СС в другую.

1). Целочисленно разделить исходное число Z(10) на основание новой системы (p) и найти остаток отделения – это будет цифра от 0-го разряда числа Z.

2). Частное от деления снова разделить на P с выделением остатка, процедуру продолжать до тех пор, пока частное не окажется меньше P.

3). Образованные остатки от деления, поставленные в порядке, обратном их получения, и представляют Z(p). Пример:

Итак, 123 (10) = 443 (5).

2. Алгоритм перевода Z(p) в Z(10).

Для этого преобразования используют формулу (1):

Где p – основание СС, k- общее число цифр числа.

443(5)=4*5 2 + 4*5 1 + 3*5 0 = 100+20+3 = 123.

3. Алгоритм перевода дробного числа из десятичной СС в другую систему.

1) Умножить исходную дробь в 10-ной системе на основание P, выделить целую часть – она будет первой цифрой новой дроби, отбросить целую часть.

2) Для оставшейся дробной части операцию умножения с выделение целой и дробной частей повторять, пока в дробной части не окажется 0 или не будет достигнута желаемая точность конечного числа.

3) Записать дробь в виде последовательности цифр после поля с разделителями в порядке их появления.

4. Алгоритм перевода 0.Y(P) в 0.Y(10) сводится к вычислению значения формулы (1).

0,0112 = 0*2 -1 + 1*2 -2 + 1*2 -3 = 0,25+0,125 = 0,37510.

Арифметические операции в двоичной системе счисления и представление чисел в других системах счисления.

1) Сложение производится согласно таблице сложения, которая для двоичных чисел имеет вид:

2) Умножение производится согласно таблице умножения.

Таким образом, умножение двоичных чисел сводится к операциям сдвига на один двоичный разряд влево и повторения первого сомножителя в тех разрядах, где второй сомножитель содержит 1, и сдвига без повторения с разрядом 0.

Источник

Перевод дробных чисел из одной системы

Счисления в другую

Примеры перевода правильных дробей в десятичную систему счисления.

1. Перевести в десятичную систему счисления число 0,10102

0,10102= 1×2 -1 + 0×2 -2 + 1×2 -3 + 0×2 -4 = 0,5 + 0,125 = 0,62510;

2. Перевести в десятичную систему счисления число 0,92416

0,92416 = 9×16 -1 + 2×16 -2 + 4×16 -3 = 9/16 + 2/256 + 4/4096 = = 2340/4096 = 0,571289062510 .

Перевод десятичной дроби в другую систему счисления производится в следующей последовательности:

— умножить исходную дробь на основание новой системы счисления;

— выделить из полученного результата целую часть и принять ее за цифру очередного разряда искомой дроби;

— если достигнута требуемая точность, то дальнейшие действия прекращаются, в противном случае из последнего результата умножения выделяется дробная часть, принимается за исходное число и описанная выше последовательность действий повторяется;

— искомая дробь в новой системе счисления записывается в виде последовательности целых частей полученных произведений, начиная с первого.

Пример

Перевести в двоичную систему счисления десятичную

дробь 0,231510 (с точностью до 5 знаков после запятой)

´2 = 0 4630

´ 2 = 09260

´ 2 = 18520

´ 2 = 17040

´2 = 14080

´ 0,231510 = 0,001112

Перевод неправильных дробей из одной системы счисления в другую выполняется по описанным выше правилам отдельно для целой и дробной частей.

Примеры

1. Перевести в двоичную систему счисления число 72,4110

72,4110 = 7210 + 0,4110

72 2

— 72 36 2

0 — 36 18 2

0 — 18 9 2

0 — 8 4 2

1 — 4 2 2

0 — 2 1

7210=10010002 0

Перевод числа 0,4110 в двоичную систему счисления производится по описанному выше алгоритму перевода десятичной дроби в другую систему счисления. В результате перевода получено следующее число:

72,4110 = 1001000,0110100…2 .

2. Перевести двоичное число в шестнадцатиричную систему счисления (путем разбиения на тетрады: для целой части справа налево, для дробной – слева направо)

1011,0111012 = 1011 , 01110100 2 = В,7416 .

Выполнение арифметических операций над числами

Арифметические операции над двоичными числами выполняются по тем же правилам, что и аналогичные операции над десятичными числами, а именно:

Двоичная Двоичная Двоичная

таблица сложения таблица вычитания таблица умножения

0 + 0 = 0 0 — 0 = 0 0 ´ 0 = 0

1 + 0 = 1 1 — 0 = 1 1 ´ 0 = 0

1 + 0 = 1 1 — 1 = 0 0 ´ 1 = 0

1 + 1 = 10 10 — 1 = 1 1 ´ 1 = 1

Пример

Выполнить сложение, вычитание, умножение и деление в двоичной системе счисления


+ 10011,110- 110001,1010

11001001 11011101101 1001

´ 1001 — 1001 11000101

11001001 1001

+ 11001001 — 1001

1001

— 1001

Кодирование алфавитно-цифровой информации

В разное время и для разных моделей компьютеров были разработаны разные коды для кодирования числовой и текстовой информации.

Рассмотрим некоторые из них.

1. Двоично-десятичный код.Используется для кодирования числовой информации. Каждая цифра представляется 4-х разрядным двоичным числом (табл. 2).

Таблица 2

Пример

Представить десятичное число 92710 в двоично-десятичном коде

92710 = 100100100111 2-10 код .

2. Код ASCII (American Standard Code for Information Interchange).Используется для кодирования чисел и текстовой информации в современных персональных компьютерах. В ASCII символы с кодами от 0 до 127 используются для представления цифр, знаков арифметических операций, букв латинского алфавита, знаков пунктуации. Символы с кодами от 128 до 255 являются дополнительными и используются для букв национальных алфавитов и символов псевдографики. В странах СНГ наиболее широкое распространение получила русская альтернативная дополнительная таблица, которая приведена в [1].

Пример

Представить фамилию Иванов в коде ASCII (используя таблицу ASCII кодов, [1, стр. 14])

Источник

Оцените статью
( Пока оценок нет )
Поделиться с друзьями
Uchenik.top - научные работы и подготовка
0 0 голоса
Article Rating
Подписаться
Уведомить о
guest
0 Комментарий
Старые
Новые Популярные
Межтекстовые Отзывы
Посмотреть все комментарии