logo
Методичка Java

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

Во время программирования различного рода внешних устройств, регистров процессора, битовыми масками, кодировке цвета, и так далее, приходится работать с кодами беззнаковых целых чисел. При этом использование десятичных чисел крайне неудобно из-за невозможности лёгкого сопоставления числа в десятичном виде и его двоичных бит. А использование чисел в двоичной кодировке крайне громоздко – получаются слишком длинные последовательности нулей и единиц. Программисты используют компромиссное решение – шестнадцатеричную кодировку чисел, где в качестве основания системы счисления выступает число 16. Очевидно, . В десятичной системе счисления имеется только 10 цифр: 0,1,2,3,4,5,6,7,8,9. А в 16-ричной системе счисления должно быть 16 цифр. Принято обозначать недостающие цифры заглавными буквами латинского алфавита: A,B,C,D,E,F. То есть

, , , , , . Таким образом, к примеру, .

В Java для того, чтобы отличать 16-ричные числа, как мы уже знаем, перед ними ставят префикс 0x: 0xFF обозначает , а 0x10 – это 1016, то есть 16.

Число N может быть записано с помощью разных систем счисления. Например, в десятичной:

N = An 10n + ... + A2 102 + A1 101 + A0 100 ( An = 0 .. 9)

или в двоичной:

N = Bn 2n + ... + B2 22 + B1 21 + B0 20 ( Bn = 0 или 1 )

или в шестнадцатеричной:

N = Cn 16n + ... + C2 162 + C1 161 + C0 160 ( Cn = 0 .. F )

Преобразование в другую систему счисления сводится к нахождению соответствующих коэффициентов. Например, Bn по известным коэффициентам An – при переводе из десятичной системы в двоичную, или коэффициентов An по коэффициентам Bn - из двоичной системы в десятичную.

Преобразование чисел из системы с меньшим основанием в систему с большим основанием

Рассмотрим преобразование из двоичной системы в десятичную. Запишем число N в виде

N = Bn 2n + ... + B2 22 + B1 21 + B0 20 ( Bn = 0 или 1 )

и будем рассматривать как алгебраическое выражение в десятичной системе. Выполним арифметические действия по правилам десятичной системы. Полученный результат даст десятичное представление числа N.

Пример:

Преобразуем 010111102 к десятичному виду. Имеем:

010111102 = 027+126+025+124+123+122+121+020=

= 0 + 64 + 0 + 16 + 8 + 4 + 2 + 0 =

= 9410

Преобразование чисел из системы с большим основанием в систему с меньшим основанием

Рассмотрим его на примере преобразования из десятичной системы в двоичную. Нужно для известного числа N10 найти коэффициенты в выражении

N = Bn 2n + ... + B2 22 + B1 21 + B0 20 ( Bn = 0 или 1 )

Воспользуемся следующим алгоритмом: в десятичной системе разделим число N на 2 с остатком. Остаток деления (он не превосходит делителя) даст коэффициент B0 при младшей степени 20. Далее делим на 2 частное, полученное от предыдущего деления. Остаток деления будет следующим коэффициентом B1 двоичной записи N. Повторяя эту процедуру до тех пор, пока частное не станет равным нулю, получим последовательность коэффициентов Bn.

Например, преобразуем 34510 к двоичному виду. Имеем:

частное остаток Bi

345 / 2 172 1 B0

172 / 2 86 0 B1

86 / 2 43 0 B2

43 / 2 21 1 B3

21 / 2 10 1 B4

10 / 2 5 0 B5

5 / 2 2 1 B6

2 / 2 1 0 B7

1 / 2 0 1 B8

34510 = 1010110012

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

Рассмотрим число N в двоичном и шестнадцатеричном представлениях.

N = Bn 2n + ... + B2 22 + B1 21 + B0 20 ( Bi = 0 или 1 )

N = Hn 16n + ... + H2 162 + H1 161 + H0 160 ( Hi = 0 .. F16 , где F16 =1510)

Заметим, что 16 = 24. Объединим цифры в двоичной записи числа группами по четыре. Каждая группа из четырех двоичных цифр представляет число от 0 до F16 , то есть от 0 до1510. От группы к группе вес цифры изменяется в 24=16 раз (основание 16-ричной системы). Таким образом, перевод чисел из двоичного представления в шестнадцатеричное и обратно осуществляется простой заменой всех групп из четырех двоичных цифр на шестнадцатеричные (по одному на каждую группу) и обратно :

00002 = 016

00012 = 116

00102 = 216

00112 = 316

01002 = 416

01012 = 516

01102 = 616

01112 = 716

10002 = 816

10012 = 916

10102 = A16

10112 = B16

11002 = C16

11012 = D16

11102 = E16

11112 = F16

Например, преобразуем 10110101112 к шестнадцатеричному виду:

10110101112 = 0010 1101 01112 = 2D716