QpmtnriLmax — различия между версиями
Zemskovk (обсуждение | вклад) м (→Источники информации) |
Zemskovk (обсуждение | вклад) |
||
Строка 12: | Строка 12: | ||
<table> | <table> | ||
<tr> | <tr> | ||
− | <td>[[Файл:Figure_5.2.png|500px|thumb|Рис. 1 | + | <td>[[Файл:Figure_5.2.png|500px|thumb|Рис. 1. Исходная сеть]]</td> |
− | <td>[[Файл:Figure_5.9.b.png|500px|thumb|Рис. 2 | + | <td>[[Файл:Figure_5.9.b.png|500px|thumb|Рис. 2. Расширение сети]]</td> |
</tr> | </tr> | ||
</table> | </table> | ||
Строка 32: | Строка 32: | ||
{{Теорема | {{Теорема | ||
|statement=Следующие утверждения эквивалентны: | |statement=Следующие утверждения эквивалентны: | ||
+ | :<tex>(a)</tex> Существует допустимое расписание. | ||
+ | :<tex>(b)</tex> В расширенной сети существует поток от <tex>s</tex> до <tex>t</tex> со значением <tex>\sum\limits_{i=1}^n p_i</tex>. | ||
− | + | |proof=<tex>(b) \Rightarrow (a)</tex> | |
− | |||
− | |||
Рассмотрим в расширенной сети поток величиной <tex>\sum\limits_{i = 1}^n {p_i}</tex>. Обозначим через <tex>x_{iK}</tex> общий поток, который идет от <tex>J_i</tex> до <tex>I_K</tex>. Заметим, что <tex>\sum\limits_{i = 1}^n \sum\limits_{K = 2}^r x_{iK} = \sum\limits_{i = 1}^n p_i</tex>. Достаточно показать, что для каждого подмножества <tex>A \subseteq \{ 1, . . . , n \}</tex> выполняется | Рассмотрим в расширенной сети поток величиной <tex>\sum\limits_{i = 1}^n {p_i}</tex>. Обозначим через <tex>x_{iK}</tex> общий поток, который идет от <tex>J_i</tex> до <tex>I_K</tex>. Заметим, что <tex>\sum\limits_{i = 1}^n \sum\limits_{K = 2}^r x_{iK} = \sum\limits_{i = 1}^n p_i</tex>. Достаточно показать, что для каждого подмножества <tex>A \subseteq \{ 1, . . . , n \}</tex> выполняется | ||
Строка 96: | Строка 96: | ||
Задача <tex>Q \mid pmtn; r_i \mid C_{max}</tex> представляет собой частный случай <tex>Q \mid pmtn; r_i \mid L_{max}</tex>, и может быть решена более эффективно<ref>Описано в Peter Brucker. «Scheduling Algorithms» {{---}} «Springer», 2006 г. {{---}} 133 стр.</ref>. | Задача <tex>Q \mid pmtn; r_i \mid C_{max}</tex> представляет собой частный случай <tex>Q \mid pmtn; r_i \mid L_{max}</tex>, и может быть решена более эффективно<ref>Описано в Peter Brucker. «Scheduling Algorithms» {{---}} «Springer», 2006 г. {{---}} 133 стр.</ref>. | ||
+ | |||
+ | ==Примечания== | ||
+ | <references> | ||
==Источники информации== | ==Источники информации== | ||
* Peter Brucker. «Scheduling Algorithms» {{---}} «Springer», 2006 г. {{---}} 129 {{---}} 133 стр. {{---}} ISBN 978-3-540-69515-8 | * Peter Brucker. «Scheduling Algorithms» {{---}} «Springer», 2006 г. {{---}} 129 {{---}} 133 стр. {{---}} ISBN 978-3-540-69515-8 | ||
− | |||
− | |||
− | |||
[[Категория: Теория расписаний]] | [[Категория: Теория расписаний]] |
Версия 22:04, 18 мая 2016
Задача: |
Рассмотрим задачу на нахождение расписания:
|
Содержание
Алгоритм
Алгоритм решения
Как в задаче применим метод двоичного поиска и сведем задачу к . Для существования расписания с требуется, чтобы у работы с номером выполнялось , что эквивалентно . Опишем алгоритм решения при помощи сведения к задаче поиска максимального потока.
Пусть
— упорядоченная последовательность всех значений и . Определим интервалы на исходной сети (Рис. 1) для . Cчитаем, что станки занумерованы в порядке невозрастания скоростей (также считаем ).Искомая сеть строится с помощью расширения сети из задачи
. Обозначим через набор предшественников узла , тогда замененная нами подсеть определяется как .Расширение сети показано на Рис. 2.
Расширенная подсеть строится путем добавления к вершинам
вершин . При , есть дуги от до с пропускной способностью и для всех и существует дуга из в с пропускной способностью . Это выполняется для каждой вершины . Кроме того, мы сохраняем дуги из в пропускной способностью и дуги из в пропускной способностью (Рис. 1).Корректность и оптимальность алгоритма
Теорема: | ||
Следующие утверждения эквивалентны:
| ||
Доказательство: | ||
Рассмотрим в расширенной сети поток величиной . Обозначим через общий поток, который идет от до . Заметим, что . Достаточно показать, что для каждого подмножества выполняется,где . Это означает, что условие выполняется и требования к обработке могут быть запланированы как для . Рассмотрим подсеть в расширенной сети в подмножестве и соответствующие части потока. Фрагмент частичного потока, который проходит через ограничен. Таким образом, мы имеем
То, что равенство справедливо, может рассматриваться как следствие. Если , то. В противном случае . Предположим, что допустимое расписание существует. Для и пусть является "объемом работ", который будет выполняться в интервале в соответствии с нашим возможным расписанием. Тогда для всех и произвольных наборов , неравенство
выполняется. Кроме того, для у нас . Остается показать, что можно отправить от до в расширенной сети. Такой поток существует, если и значение ограничено величиной минимального разреза части сети с истоками и стоком . Тем не менее, это значение
Используя и правую часть , получаемчто и является искомым неравенством. | ||
Время работы
Работа с максимальным потоком в расширенной сети занимает
шагов, проверка может быть сделана с такой же скоростью. Для решения мы используем бинарный поиск, а значит, получаем алгоритм с -приближенной сложностью , потому как , ограничен , при .Задача [1].
представляет собой частный случай , и может быть решена более эффективноПримечания
<references>
Источники информации
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 129 — 133 стр. — ISBN 978-3-540-69515-8
- ↑ Описано в Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 133 стр.