Рекурсивное индексирование - Recursive indexing

Когда число (обычно большое число) представлено в конечном алфавитном наборе, и оно не может быть представлено только одним членом этого набора, рекурсивное индексирование используется.

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

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

Кодирование

Чтобы закодировать число N, продолжайте уменьшать максимальный элемент этого набора (SМаксимум) из N и вывод Smax для каждой такой разницы, останавливаясь, когда число находится в полузакрытом полуоткрытом диапазоне [0 -SМаксимум).

Пример:

Позволять S = [0 1 2 3 4… 10], будет набором из 11 элементов, и мы должны рекурсивно проиндексировать значение N = 49.

Согласно этому методу, нам нужно продолжать удалять 10 из 49 и продолжать, пока не достигнем числа в диапазоне 0–10.

Значит, значения 10 (N = 49 – 10 = 39), 10 (N = 39 – 10 = 29), 10 (N = 29 – 10 = 19), 10 (N = 19 - 10 = 9), 9. Следовательно, рекурсивно проиндексированная последовательность для N = 49 с набором S, это 10, 10, 10, 10, 9.

Расшифровка

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

Пример:

Продолжая пример выше, мы имеем 10 + 10 + 10 + 10 + 9 = 49.

Использует

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

Рекомендации