Итак, у меня есть проблема, которая в основном такова: у меня есть куча строк, и я хочу построить DAG так, чтобы каждый путь соответствовал строке, и наоборот.Однако у меня есть свобода произвольно переставлять мои струны.Порядок символов не имеет значения.Сгенерированные мной группы доступности баз данных связаны с затратами.По сути, стоимость ветви в группе обеспечения доступности баз данных пропорциональна длине дочерних путей.
Например, допустим, у меня есть строки BAAA, CAAA, DAAA, и я создаю группу DAG, представляющую их без перестановки.их.Я получаю:
() -> (B, C, D) -> A -> A -> A
, где кортеж представляет ветвление.
Более дешевое представлениедля моих целей было бы:
() -> A -> A -> A -> (B, C, D)
Проблема заключается в следующем: учитывая n строк, переставлять строки, такиечто соответствующая группа обеспечения доступности баз данных имеет самую дешевую стоимость, где функция стоимости: если мы сначала проследим график от источника в глубину, слева направо, общее число посещаемых нами узлов с кратностью.
Итакстоимость первого примера - 12, потому что мы должны посетить A несколько раз при обходе.Стоимость второго примера - 6, потому что мы посещаем A только один раз, прежде чем имеем дело с ветвями.
У меня есть ощущение, что эта проблема - NP Hard.Это похоже на вопрос о формальных языках, и я не достаточно знаком с такими алгоритмами, чтобы понять, как я должен идти к сокращению.Мне не нужен полный ответ сам по себе, но если бы кто-то мог указать на класс хорошо известных проблем, которые кажутся связанными, я был бы очень признателен.