QpmtnriLmax — различия между версиями
Строка 38: | Строка 38: | ||
}} | }} | ||
==Время работы== | ==Время работы== | ||
− | [[Файл:Figure_5.9.a.png| | + | [[Файл:Figure_5.9.a.png|200px|thumb|right|Рис. 2.1]] |
[[Файл:Figure_5.9.b.png|400px|thumb|right|Рис. 2.2]] | [[Файл:Figure_5.9.b.png|400px|thumb|right|Рис. 2.2]] | ||
Из-за максимального потока в расширенной сети могут быть рассчитаны в <tex>O (m n^3)</tex> шагов, возможность проверки может быть сделано с такой же сложности. | Из-за максимального потока в расширенной сети могут быть рассчитаны в <tex>O (m n^3)</tex> шагов, возможность проверки может быть сделано с такой же сложности. | ||
Строка 44: | Строка 44: | ||
Для решения задачи <tex>Q|pmtn; r_{i}|L_{max}</tex> мы используем бинарный поиск. Это дает <tex>\varepsilon</tex>-приближении алгоритм со сложностью <tex>O (mn^3(log(n) + log(1 / \varepsilon) + log (\max\limits_{i=1}^{n} p_i)) </tex>, потому что <tex>L_{max}</tex>, ограничен <tex>n \max\limits_{i=1}^{n}p_i</tex>, при <tex>s_1 = 1</tex>. | Для решения задачи <tex>Q|pmtn; r_{i}|L_{max}</tex> мы используем бинарный поиск. Это дает <tex>\varepsilon</tex>-приближении алгоритм со сложностью <tex>O (mn^3(log(n) + log(1 / \varepsilon) + log (\max\limits_{i=1}^{n} p_i)) </tex>, потому что <tex>L_{max}</tex>, ограничен <tex>n \max\limits_{i=1}^{n}p_i</tex>, при <tex>s_1 = 1</tex>. | ||
− | Потому что (5.10) справедливо для всех К частичной работы с требования к обработке Xik могут быть запланированы в ИК с уровнем алгоритма. | + | Потому что (5.10) справедливо для всех К частичной работы с требования к |
+ | обработке Xik могут быть запланированы в ИК с уровнем алгоритма. | ||
Задача <tex>Q | pmtn; ri | Cmax</tex>, которая представляет собой частный случай <tex>Q | pmtn; ri | Lmax</tex>, может быть решена более эффективно. Labetoulle, Lawler, Lenstra, and Rinnooy Kan разработали алгоритм работающий за <tex> O(n log(n) + mn) </tex> специально для этого случая. | Задача <tex>Q | pmtn; ri | Cmax</tex>, которая представляет собой частный случай <tex>Q | pmtn; ri | Lmax</tex>, может быть решена более эффективно. Labetoulle, Lawler, Lenstra, and Rinnooy Kan разработали алгоритм работающий за <tex> O(n log(n) + mn) </tex> специально для этого случая. | ||
Строка 50: | Строка 51: | ||
Задача <tex>Q | pmtn | Lmax</tex> может быть решена за <tex> O(n log(n) + mn) </tex> шагов. Это вытекает из следующих соображений: | Задача <tex>Q | pmtn | Lmax</tex> может быть решена за <tex> O(n log(n) + mn) </tex> шагов. Это вытекает из следующих соображений: | ||
− | Решение <tex>Q | pmtn; ri | Cmax</tex> эквивалентно нахождению наименьшего <tex>T \ge 0</tex>, что проблема с временными окнами [г, т] (г = 1, ..., п) имеет возможности решение. | + | Решение <tex>Q | pmtn; ri | Cmax</tex> эквивалентно нахождению наименьшего |
+ | <tex>T \ge 0</tex>, что проблема с временными окнами [г, т] (г = 1, ..., п) | ||
+ | имеет возможности решение. | ||
− | С другой стороны, решение <tex>Q | pmtn | Lmax</tex> эквивалентно нахождению такого наименьшего <tex>T \ge 0</tex>, что проблема с временными окнами [0, D + T] или с временными окнами [-T, ди] имеет допустимое решение. | + | С другой стороны, решение <tex>Q | pmtn | Lmax</tex> эквивалентно нахождению |
+ | такого наименьшего <tex>T \ge 0</tex>, что проблема с временными окнами | ||
+ | [0, D + T] или с временными окнами [-T, ди] имеет допустимое решение. | ||
Таким образом, задачи <tex>Q | pmtn; ri | Cmax</tex> и <tex>Q | pmtn | Lmax</tex> симметричны. | Таким образом, задачи <tex>Q | pmtn; ri | Cmax</tex> и <tex>Q | pmtn | Lmax</tex> симметричны. |
Версия 19:14, 22 мая 2012
Эта статья находится в разработке!
Постановка задачи
Рассмотрим задачу нахождения расписания со следующим свойством:
- Каждое задание имеет своё времени выпуска
и срок завершения(дедлайн) .Алгоритм решения
Применим бинарный поиск для общего решения задачи. Сведем задачу к поиску потока сети.
Пусть
упорядоченная последовательности всех значений и .Также определим
для .Далее мы расширяем сеть, показанную на рисунке 1 следующим образом:
- произвольный интервал узел на рисунке, обозначим через набор предшественников узла .
Тогда замененная нами подсеть определяется как TODO: ДОБАВИТЬ_Рисунок 5.9: Расширение сети.
, которая показана на рисунке 5.9 (а), расширение сети показано на рисунке 5.9 (б).Cчитаем, что машины индексируются в порядке невозрастания скоростей
, кроме того .Расширенная подсеть строится путем добавления к вершинам
вершин .При
, есть дуги от до with capacity и для всех и существует дуга из в with capacity .Для каждого
у нас есть такие расширения. Кроме того, мы сохраняем дуги от до и мощностью дуг из в мощностью (см. рисунок 5.2). Сеть построена таким образом, называется расширенной сетью.Теорема: |
Следующие свойства эквивалентны:
(А) Существует допустимое расписание. (Б) В расширенной сети существует поток от s до t со значением |
Время работы
Из-за максимального потока в расширенной сети могут быть рассчитаны в
шагов, возможность проверки может быть сделано с такой же сложности.Для решения задачи
мы используем бинарный поиск. Это дает -приближении алгоритм со сложностью , потому что , ограничен , при .Потому что (5.10) справедливо для всех К частичной работы с требования к обработке Xik могут быть запланированы в ИК с уровнем алгоритма.
Задача
, которая представляет собой частный случай , может быть решена более эффективно. Labetoulle, Lawler, Lenstra, and Rinnooy Kan разработали алгоритм работающий за специально для этого случая.Задача
может быть решена за шагов. Это вытекает из следующих соображений:Решениеэквивалентно нахождению наименьшего , что проблема с временными окнами [г, т] (г = 1, ..., п) имеет возможности решение.
С другой стороны, решениеэквивалентно нахождению такого наименьшего , что проблема с временными окнами [0, D + T] или с временными окнами [-T, ди] имеет допустимое решение.
Таким образом, задачи
и симметричны.