QpmtnriLmax — различия между версиями
| Строка 1: | Строка 1: | ||
| − | |||
<includeonly>[[Категория: В разработке]]</includeonly> | <includeonly>[[Категория: В разработке]]</includeonly> | ||
| + | |||
| + | [[Файл:Figure_5.2.png|400px|thumb|right|Рис. 1]] | ||
==Постановка задачи== | ==Постановка задачи== | ||
| − | |||
Рассмотрим еще одну задачу на нахождение расписания: | Рассмотрим еще одну задачу на нахождение расписания: | ||
| Строка 37: | Строка 37: | ||
(Б) В расширенной сети существует поток от s до t со значением <tex>\sum\limits_{i=1}^{n} p_i</tex> | (Б) В расширенной сети существует поток от s до t со значением <tex>\sum\limits_{i=1}^{n} p_i</tex> | ||
}} | }} | ||
| + | [[Файл:Figure_5.9.b.png|500px|thumb|right|Рис. 2.2 - Расширение сети]] | ||
==Время работы== | ==Время работы== | ||
| − | |||
Из-за максимального потока в расширенной сети могут быть рассчитаны в <tex>O (m n^3)</tex> шагов, возможность проверки может быть сделано с такой же сложности. Для решения задачи <tex>Q|pmtn; r_{i}|L_{max}</tex> мы используем бинарный поиск. Получается алгоритм со сложностью <tex>O (mn^3(log(n) + 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>O (m n^3)</tex> шагов, возможность проверки может быть сделано с такой же сложности. Для решения задачи <tex>Q|pmtn; r_{i}|L_{max}</tex> мы используем бинарный поиск. Получается алгоритм со сложностью <tex>O (mn^3(log(n) + 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>. | ||
Версия 12:00, 29 мая 2012
Постановка задачи
Рассмотрим еще одну задачу на нахождение расписания:
1) Каждое задание имеет своё времени выпуска .
2) Срок завершения(дедлайн) .
Требуется минимизировать опоздание
Алгоритм решения
Применим бинарный поиск. Таким образом сведем задачу к поиску потока сети.
Пусть упорядоченная последовательности всех значений и . Определим для .
Расширим сеть, показанную на Рис. 1 следующим образом:
- произвольный интервал-узел. Обозначим через набор предшественников узла , тогда замененная нами подсеть(Рис. 2.1) определяется как . Расширение сети показано на Рис 2.2.
Cчитаем, что станки индексируются в порядке невозрастания скоростей , кроме того .
Расширенная подсеть строится путем добавления к вершинам вершин . При , есть дуги от до с емкостью и для всех и существует дуга из в с емкостью .
Для каждого у нас есть такие расширения. Кроме того, мы сохраняем дуги из в емкостью и дуги из в емкостью (см. рисунок 1).
| Теорема: |
Следующие свойства эквивалентны:
(А) Существует допустимое расписание. (Б) В расширенной сети существует поток от s до t со значением |
Время работы
Из-за максимального потока в расширенной сети могут быть рассчитаны в шагов, возможность проверки может быть сделано с такой же сложности. Для решения задачи мы используем бинарный поиск. Получается алгоритм со сложностью , потому что , ограничен , при .
представляет собой частный случай , и может быть решена более эффективно. Labetoulle, Lawler, Lenstra, и Rinnooy Kan разработали алгоритм работающий за специально для этого случая.
| Утверждение: |
Задача может быть решена за шагов. |
|
Решение эквивалентно нахождению наименьшего , такого, что задача с "временными окнами" имеет решение. С другой стороны, решение эквивалентно нахождению такого наименьшего , такого, что задача с "временными окнами" или с "временными окнами" имеет решение. |
Таким образом, задачи и симметричны.
Источники
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 379 стр. — ISBN 978-3-540-69515-8