Изменения

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

Получение следующего объекта

3 байта убрано, 21:08, 2 января 2014
Специализация алгоритма для генерации следующей перестановки
== Специализация алгоритма для генерации [http://neerc.ifmo.ru/wiki/index.php?title=%D0%9A%D0%BE%D0%BC%D0%B1%D0%B8%D0%BD%D0%B0%D1%82%D0%BE%D1%80%D0%BD%D1%8B%D0%B5_%D0%BE%D0%B1%D1%8A%D0%B5%D0%BA%D1%82%D1%8B#.D0.9F.D1.80.D0.B8.D0.BC.D0.B5.D1.80.D1.8B_.D0.BA.D0.BE.D0.BC.D0.B1.D0.B8.D0.BD.D0.B0.D1.82.D0.BE.D1.80.D0.BD.D1.8B.D1.85_.D0.BE.D0.B1.D1.8A.D0.B5.D0.BA.D1.82.D0.BE.D0.B2 следующей перестановки] ==
* Двигаясь справа налево, находим элаементэлемент, нарушающий убывающую последовательность (в обычном порядке, слева направо, см. пример)
* Меняем его с минимальным элементом, большим нашего, стоящим правее
* Перевернем правую часть
'''function''' nextPeremutationnextPermutation(a:array[1..n] of integer):array[1..n] of integer; // n - длина перестановки
'''for''' i = n - 1 '''downto''' 1
'''if''' a[i] < a[i + 1]
76
правок

Навигация