Я читал о том, как перестановочные графики делают много NP-полных проблем намного легче решить. Например, проблема максимальной клики, проблема ширины дерева и т. Д. Однако я не могу понять процесс создания графа перестановок из заданного графа G (V, E). Как бы это сделать?Построение графа перестановок
2
A
ответ
3
Вы не можете создать граф перестановок из графика, но из перестановки. Процесс довольно прост:
- номера записи 1 до п на линии, то
- записать их снова на отдельной параллельной линии в соответствии с порядком, в котором они появляются в вашей перестановки;
- подключить каждый элемент от первой строки к тому же элементу на второй строке (от 1 до 1, от 2 до 2, ..., от n до n),
- отметьте каждое такое соединение с номерами, которые он соединяет (например, соединение 2 - 2 принимает метку 2);
- полученный граф перестановки получается путем обработки каждого соединения в виде вершины и соединения двух вершин всякий раз, когда соответствующие соединения пересекаются.
Если это еще не ясно, see the nice example on Wikipedia.
Из процесса ясно, что такой график всегда можно построить из любой перестановки; однако, наличие перестановочного графа может привести к выведению нескольких перестановок, соответствующих ему.
Смежные вопросы
- 1. Построение графа «смежных» строк
- 2. Reflection.Emit Построение графа сущности
- 3. Построение структуры графа в haskell
- 4. Построение графа зависимости пакета Scala
- 5. Построение неизменяемого графа с круговыми ссылками
- 6. построение графа с неизвестным параметром, содержащим ехр
- 7. Построение распределения графа в Python iGraph
- 8. Построение графа вычислений с помощью выражения
- 9. Эффективное построение графа подобия с погрешностью
- 10. Построение двоичного переменного графа в excel
- 11. сгенерируйте список перестановок, которые сохраняют заданное разбиение (контекст: изоморфизм графа)
- 12. Построение графа и преобразование его в представление CSR
- 13. Guice 3 - Автоматическое построение графа объектов при использовании вспомогательной инъекции
- 14. Построение графа объекта из плоского массива объектов в JavaScript
- 15. ускорение графика графа построение графика; добавление свойств края итеративно
- 16. Построение графа с пользовательскими операциями в тензорном потоке
- 17. Расчет возможных перестановок массива чисел
- 18. Создайте подмножество возможных перестановок
- 19. матрица перестановок
- 20. Алгоритм перестановок
- 21. Невозможно сопоставить сравнение графа графа
- 22. Одиночный код динамического графа
- 23. Flink - Построение графика оператора
- 24. Создание классов для представления различных перестановок типа
- 25. Построение всех перестановок определенной строки и сверить его со словарем эффективно
- 26. Действительно большой список перестановок
- 27. GWT Количество перестановок
- 28. Функция сопоставления перестановок
- 29. Распределение перестановок в r
- 30. Regex блоки перестановок
Я думаю, вы немного ошибаетесь. Пермутационные графики - это конкретный экземпляр графов, которые некоторые проблемы, которые * обычно * NP-Hard, решаются специально на этих графах эффективно - подобно [двучастному графу] (http://en.wikipedia.org/wiki/ Bipartite_graph) [Хотя это разные графы, конечно]. Не каждый граф является перестановочным графом. И маловероятно, что вы можете полиномиально преобразовать любой граф в график перестановок - это сделает P = NP. – amit
@amit вы должны написать это как ответ – alestanis