Изменения

Перейти к: навигация, поиск

Получение объекта по номеру

115 байт добавлено, 16:21, 10 декабря 2014
Описание алгоритма
Получаем элементы объекта по порядку: сначала определим какой элемент будет стоять на первом месте, потом на втором и так далее. Считаем, что мы нашли первые <tex>i</tex> элементов объекта. Для всех вариантов элемента, который может стоять на позиции с номером <tex>i+1</tex>, посчитаем диапазон номеров, который будет соответствовать объектам с данным префиксом. Если искомый номер входит в один из диапазонов, то, очевидно, мы нашли элемент, который должен стоять на месте с номером <tex>i+1</tex>. Диапазоны номеров не пересекаются, значит на это место больше нельзя поставить никакой другой элемент.
*В начале каждого шага <tex>\mathtt{numOfObject }</tex> {{---}} номер нужного объекта среди тех, у которых префикс до <tex>i</tex>-го элемента лексикографически равен префиксу нашего объекта.
*<tex>\mathtt{n }</tex> {{---}} количество мест в комбинаторном объекте (например, битовый вектор длины <tex>n</tex>)
*<tex>\mathtt{k }</tex> {{---}} количество различных элементов, которые могут находиться в данном комбинаторном объекте. Например, для битового вектора <tex>k=2</tex>, поскольку возможны только <tex>0 </tex> и <tex>1</tex>. Все элементы занумерованы в лексикографическом порядке, начиная с <tex>1</tex>.Комбинаторные объекты занумерованы с <tex>0</tex>. Переход к нумерации с единицы можно сделать с помощью одной операции декремента перед проходом алгоритма.
'''function''' num2object(numOfObject: '''int''')
'''for''' i = 1 '''to''' n '''do'''
29
правок

Навигация