Предположим, два списка сопоставимых предметов: и и с. Пусть INV (u) будет числом инверсий в u.
Я ищу эффективный алгоритм для вставки элементов s в вас с минимальным увеличением INV (u).
По сути, я хотел бы вставлять объекты в список, сохраняя его «как можно более отсортированным», сохраняя порядок первого списка.
Пример:
u = [4,6,2,9,7]
INV(u) = 3 ((4, 2), (6, 2) and (9, 7)
s = [8,3,10]
one optimal solution u' = [3, 4, 6, 2, 8, 9, 7, 10]
INV(u') = 5 ((4, 2), (7, 2) and (9, 7) + (3,2), (8,7))
different optimal solution u' = [3, 4, 6, 2, 9, 7, 8, 10]
INV(u') = 5 ((4, 2), (7, 2) and (9, 7) + (3,2), (9,8))
Как видите, единственного оптимального решения не существует.
Я был бы рад за любые идеи или направления для изучения.