P2precpi1Lmax — различия между версиями
м (rollbackEdits.php mass rollback) |
|||
(не показано 7 промежуточных версий 4 участников) | |||
Строка 1: | Строка 1: | ||
− | == | + | <tex dpi = "200" >P2 \mid prec, p_i=1 \mid L_{max}</tex> |
+ | |||
+ | {{Шаблон:Задача | ||
+ | |definition = | ||
Даны два одинаковых станка, на которых необходимо обработать <tex>n</tex> деталей. | Даны два одинаковых станка, на которых необходимо обработать <tex>n</tex> деталей. | ||
Каждую деталь можно обрабатывать на любом станке. Время, необходимое для обработки любой детали, | Каждую деталь можно обрабатывать на любом станке. Время, необходимое для обработки любой детали, | ||
Строка 7: | Строка 10: | ||
разность между временем, когда была закончена обработка детали, и временем дедлайна для этой | разность между временем, когда была закончена обработка детали, и временем дедлайна для этой | ||
детали. | детали. | ||
+ | }} | ||
+ | |||
==Описание алгоритма== | ==Описание алгоритма== | ||
Полагаем, что ребра в графе ориентированы от работы, к работам, зависимым от нее. | Полагаем, что ребра в графе ориентированы от работы, к работам, зависимым от нее. | ||
− | Введем понятие ''вынужденного'' дедлайна <tex>d'_i</tex> {{---}} | + | Введем понятие ''вынужденного'' дедлайна <tex>d'_i</tex> {{---}} максимальное время, до которого необходимо выполнить <tex>i</tex>-ю работу, чтобы успеть |
− | выполнить все работы из <tex>S(i)</tex>, где <tex>S(i)</tex> | + | выполнить все работы из <tex>S(i)</tex>, где <tex>S(i)</tex> {{---}} множество работ, зависящих (не обязательно непосредственно) от <tex>i</tex>-й работы. |
Заметим, что эта величина может принимать отрицательные значения. | Заметим, что эта величина может принимать отрицательные значения. | ||
Обозначим через <tex>g(i, d)</tex> количество работ <tex>k</tex> из <tex>S(i)</tex>, | Обозначим через <tex>g(i, d)</tex> количество работ <tex>k</tex> из <tex>S(i)</tex>, | ||
− | таких что <tex>d'_k \ | + | таких что <tex>d'_k \leqslant d</tex>. |
{{Утверждение | {{Утверждение | ||
− | |statement=Пусть уже посчитаны работы для всех <tex>j \in S(i)</tex>. Тогда, если <tex>j \in S(i)</tex>, то <tex>i</tex>- | + | |statement=Пусть уже посчитаны работы для всех <tex>j \in S(i)</tex>. Тогда, если <tex>j \in S(i)</tex>, то <tex>i</tex>-я работа |
− | должна быть закончена до <tex>d'_j - \lceil \ | + | должна быть закончена до <tex>d'_j - \left\lceil \dfrac{g(i, d'_j)}{2} \right\rceil</tex>. |
− | |proof=Рассмотрим все работы <tex>k \in S(i)</tex>, для которых <tex>d'_k \ | + | |proof=Рассмотрим все работы <tex>k \in S(i)</tex>, для которых <tex>d'_k \leqslant d'_j</tex>. Все эти работы будут выполнены после |
− | окончания обработки детали с номером <tex>i</tex>. Для них <tex>d'_k \ | + | окончания обработки детали с номером <tex>i</tex>. Для них <tex>d'_k \leqslant d'_j</tex>. Пусть работу <tex>i</tex> закончили выполнять в |
момент времени <tex>d</tex>. Нужно до момента времени <tex>d'_j</tex> выполнить ещё <tex>g(i, d'_j)</tex> работ. | момент времени <tex>d</tex>. Нужно до момента времени <tex>d'_j</tex> выполнить ещё <tex>g(i, d'_j)</tex> работ. | ||
− | Так как в нашем распоряжении находятся две машины, то время их выполнения будет не менее, чем <tex>\lceil \ | + | Так как в нашем распоряжении находятся две машины, то время их выполнения будет не менее, чем <tex>\left\lceil \dfrac{g(i, d'_j)}{2} \right\rceil</tex>. |
− | Поскольку необходимо выполнить все эти работы до <tex>d'_j</tex>, то <tex>i</tex>- | + | Поскольку необходимо выполнить все эти работы до <tex>d'_j</tex>, то <tex>i</tex>-я работа должна быть закончена до момента времени |
− | <tex>d'_j - \lceil \ | + | <tex>d'_j - \left\lceil \dfrac{g(i, d'_j)}{2} \right\rceil</tex>. |
}} | }} | ||
− | Тогда финально получаем формулу для вычисления «вынужденного» дедлайна для <tex>i</tex>- | + | Тогда финально получаем формулу для вычисления «вынужденного» дедлайна для <tex>i</tex>-й работы: |
− | <tex>d'_i = \min\{d_i, \min\{d'_j - \lceil \ | + | <tex>d'_i = \min\{d_i, \min\{d'_j - \left\lceil \dfrac{g(i, d'_j)}{2} \right\rceil\}\}</tex>, где <tex>j \in S(i)</tex>. |
Для вершин, исходящая степень которых равна нулю, по определению вынужденного дедлайна, считаем его равным обычному дедлайну. | Для вершин, исходящая степень которых равна нулю, по определению вынужденного дедлайна, считаем его равным обычному дедлайну. | ||
Для подсчета вынужденных дедлайнов будем поддерживать список <tex>L</tex>, содержащий вершины, отсортированные в порядке | Для подсчета вынужденных дедлайнов будем поддерживать список <tex>L</tex>, содержащий вершины, отсортированные в порядке | ||
Строка 35: | Строка 40: | ||
Пусть на текущем шаге мы рассматриваем работу с | Пусть на текущем шаге мы рассматриваем работу с | ||
номером <tex>i</tex>. Перебирая вершины из <tex>S(i)</tex> в порядке списка <tex>L</tex>, пересчитываем вынужденный дедлайн для | номером <tex>i</tex>. Перебирая вершины из <tex>S(i)</tex> в порядке списка <tex>L</tex>, пересчитываем вынужденный дедлайн для | ||
− | <tex>i</tex>- | + | <tex>i</tex>-й вершины по формуле, указанной выше, после чего обновляем дедлайн этой вершины в списке <tex>L</tex>. |
После подсчета вынужденных дедлайнов, оптимальное расписание считается жадным алгоритмом. | После подсчета вынужденных дедлайнов, оптимальное расписание считается жадным алгоритмом. | ||
На каждом шаге на для обработки на станках выбираются работы с минимальным вынужденным дедлайном, для которых все необходимые | На каждом шаге на для обработки на станках выбираются работы с минимальным вынужденным дедлайном, для которых все необходимые | ||
− | работы уже выполнены. Одновременно с этим считается максимальное опоздание. | + | работы уже выполнены. Одновременно с этим считается максимальное опоздание. |
==Доказательство корректности== | ==Доказательство корректности== | ||
Строка 58: | Строка 63: | ||
такую, что <tex>\forall k \in S(i) : d'_k </tex> {{---}} не нарушено. Это всегда можно сделать в силу ацикличности графа. | такую, что <tex>\forall k \in S(i) : d'_k </tex> {{---}} не нарушено. Это всегда можно сделать в силу ацикличности графа. | ||
Рассмотрим формулу для подсчёта вынужденного дедлайна: | Рассмотрим формулу для подсчёта вынужденного дедлайна: | ||
− | <tex>d'_i = \min\{d_i, \min\{d'_j - \lceil \ | + | <tex>d'_i = \min\{d_i, \min\{d'_j - \left\lceil \dfrac{g(i, d'_j)}{2} \right\rceil\}\}</tex>, где <tex>j \in S(i)</tex>. |
− | Минимум | + | Минимум достигатся либо на <tex>d_i</tex>, что невозможно в силу того, что обычные дедлайны не нарушены, либо на каком-то |
− | <tex>j \in S(i)</tex>. В этом случае, <tex>d'_i = d'_j - \lceil\ | + | <tex>j \in S(i)</tex>. В этом случае, <tex>d'_i = d'_j - \left\lceil\dfrac{g(i, d'_j)}{2}\right\rceil</tex>. |
Значит, если <tex>d'_i</tex> нарушено, то будет также нарушен вынужденный дедлайн для какого-то <tex>k \in S(i)</tex>, | Значит, если <tex>d'_i</tex> нарушено, то будет также нарушен вынужденный дедлайн для какого-то <tex>k \in S(i)</tex>, | ||
− | так как осталось меньше, чем <tex>d'_j - d'_i > \lceil \ | + | так как осталось меньше, чем <tex>d'_j - d'_i > \left\lceil \dfrac{g(i, d'_j)}{2} \right\rceil</tex> единиц времени. Это |
противоречит условии выбора <tex>i</tex>. | противоречит условии выбора <tex>i</tex>. | ||
}} | }} | ||
Строка 71: | Строка 76: | ||
|statement= Если существует расписание без опоздание, то приведенный выше алгоритм найдет такое расписание. | |statement= Если существует расписание без опоздание, то приведенный выше алгоритм найдет такое расписание. | ||
|proof= Пусть <tex>x(1), x(2),...,x(n)</tex> {{---}} расписание, построенное этим алгоритмом, где <tex>x(i)</tex> {{---}} время | |proof= Пусть <tex>x(1), x(2),...,x(n)</tex> {{---}} расписание, построенное этим алгоритмом, где <tex>x(i)</tex> {{---}} время | ||
− | начала обработки <tex>i</tex>- | + | начала обработки <tex>i</tex>-й детали. Пусть в этом расписании существует работа, опаздывающая по обычным дедлайнам. Согласно |
утверждению 1, в этом расписании также существует работа, опаздывающая по "вынужденным" дедлайнам. Пусть <tex>i</tex> {{---}} такая работа с | утверждению 1, в этом расписании также существует работа, опаздывающая по "вынужденным" дедлайнам. Пусть <tex>i</tex> {{---}} такая работа с | ||
− | минимальным временем начала, то есть, | + | минимальным временем начала, то есть, удовлетворяющая следующему условию: <tex>d'_i < x(i) + 1</tex>. |
Следуя алгоритму, в каждый момент времени | Следуя алгоритму, в каждый момент времени | ||
− | <tex>t</tex>, такой что <tex>t < x(i)</tex>, хотя бы одна работа с номером <tex>j</tex>, такая что <tex>d'_j \ | + | <tex>t</tex>, такой что <tex>t < x(i)</tex>, хотя бы одна работа с номером <tex>j</tex>, такая что <tex>d'_j \leqslant d'_i</tex> должна |
− | быть выполнена, так как, иначе, по алгоритму, вместо <tex>i</tex> на этом шаге была бы выбрана работа <tex>j</tex>, имеющая меньшее | + | быть выполнена, так как, иначе, по алгоритму, вместо <tex>i</tex>-й на этом шаге была бы выбрана работа <tex>j</tex>, имеющая меньшее |
<tex>d'</tex> и, по построению модифицированных дедлайнов, независимая от <tex>i</tex>. | <tex>d'</tex> и, по построению модифицированных дедлайнов, независимая от <tex>i</tex>. | ||
Рассмотрим два случая. | Рассмотрим два случая. | ||
− | '''Первый случай''': в какой-то момент времени только одна работа с номером <tex>k</tex>, такая что <tex>d'_k \ | + | '''Первый случай''': в какой-то момент времени только одна работа с номером <tex>k</tex>, такая что <tex>d'_k \leqslant d'_i</tex> выполнена. |
Выберем максимальное время <tex>t</tex>, такое что <tex>t < x(i)</tex>, обладающее таким свойством. Тогда для всех работ c номером | Выберем максимальное время <tex>t</tex>, такое что <tex>t < x(i)</tex>, обладающее таким свойством. Тогда для всех работ c номером | ||
− | <tex>j</tex>, которые выполнялись в момент времени с <tex>t+1</tex> до <tex>x(i)</tex> выполняется <tex>d'_j \ | + | <tex>j</tex>, которые выполнялись в момент времени с <tex>t+1</tex> до <tex>x(i)</tex> выполняется <tex>d'_j \leqslant d'_i</tex>, кроме того, |
ни один станок не простаивал в течении этого периода. Все работы <tex>j</tex>, выполненные в период <tex>[t+1; x(i)]</tex>, а также, | ни один станок не простаивал в течении этого периода. Все работы <tex>j</tex>, выполненные в период <tex>[t+1; x(i)]</tex>, а также, | ||
работа <tex>i</tex>, должны быть зависимы от <tex>k</tex>, потому что, иначе, только <tex>j</tex> должна быть выполнена до | работа <tex>i</tex>, должны быть зависимы от <tex>k</tex>, потому что, иначе, только <tex>j</tex> должна быть выполнена до | ||
момента времени <tex>t+1</tex>. Так как было опоздание, | момента времени <tex>t+1</tex>. Так как было опоздание, | ||
− | <tex>\left\lceil \ | + | <tex>\left\lceil \dfrac{g'(k, d'_i)}{2} \right\rceil \geqslant \left\lceil\dfrac{2(x(i) - t) - 1}{2} \right\rceil = x(i) - t</tex> |
Из определения вынужденных дедлайнов, | Из определения вынужденных дедлайнов, | ||
− | <tex>d'_k \ | + | <tex>d'_k \leqslant d'_i - \left\lceil \dfrac{g(k, d'_i)}2 \right\rceil</tex> |
− | <tex>\ | + | <tex>\leqslant d'_i - x(i) + t < x(i) + 1 - x(i) + t = t + 1</tex> |
Значит, работа <tex>k</tex> тоже опоздала, что противоречит минимальности выбора <tex>x(i)</tex>. | Значит, работа <tex>k</tex> тоже опоздала, что противоречит минимальности выбора <tex>x(i)</tex>. | ||
− | '''Второй случай''': в каждый момент времени такой, что <tex>0 \ | + | '''Второй случай''': в каждый момент времени такой, что <tex>0 \leqslant t < x(i)</tex> выполняются две работы. По написанному выше, |
− | для всех этих работ <tex>j</tex>, выполняется <tex>d'_j \ | + | для всех этих работ <tex>j</tex>, выполняется <tex>d'_j \leqslant d'_i</tex>. |
− | Тогда есть хотя бы <tex>2x(i) + 1</tex> работ таких, что <tex>d'_j \ | + | Тогда есть хотя бы <tex>2x(i) + 1</tex> работ таких, что <tex>d'_j \leqslant d'_i < x(i) + 1</tex>. |
Их невозможно сделать за <tex>x(i)</tex> времени, а значит, в каждом таком расписании есть опоздание. | Их невозможно сделать за <tex>x(i)</tex> времени, а значит, в каждом таком расписании есть опоздание. | ||
}} | }} | ||
Строка 109: | Строка 114: | ||
Рассмотрим остальные в порядке топологической сортировки. Тогда, по индукции, для всех потомков рассматриваемой вершины | Рассмотрим остальные в порядке топологической сортировки. Тогда, по индукции, для всех потомков рассматриваемой вершины | ||
− | утверждение будет верно. Также, так как <tex>d'_k + l \ | + | утверждение будет верно. Также, так как <tex>d'_k + l \leqslant d'_j + l \iff d'_k \leqslant d'_j</tex>, |
− | <tex>(d_i + l)' = \min\{d_i + l, \min\{d'_j + l - \lceil\ | + | <tex>(d_i + l)' = \min\{d_i + l, \min\{d'_j + l - \left\lceil\dfrac{g(i, d'_j)}{2}\right\rceil\}\}</tex> для <tex>j \in S(i)</tex>. |
Вынеся за минимум общее слагаемое, по определению вынужденных дедлайнов, получим искомую формулу <tex>(d_i + l)' = d'_i + l</tex> | Вынеся за минимум общее слагаемое, по определению вынужденных дедлайнов, получим искомую формулу <tex>(d_i + l)' = d'_i + l</tex> | ||
Строка 117: | Строка 122: | ||
{{Теорема | {{Теорема | ||
− | |statement=Алгоритм строит оптимальное расписание | + | |statement=Алгоритм строит оптимальное расписание. |
|proof= | |proof= | ||
Пускай каким-то образом было вычислено оптимальное значение <tex>l_{max}</tex>. Тогда, по второму утверждению, если сдвинуть все | Пускай каким-то образом было вычислено оптимальное значение <tex>l_{max}</tex>. Тогда, по второму утверждению, если сдвинуть все | ||
Строка 129: | Строка 134: | ||
==Сложность алгоритма== | ==Сложность алгоритма== | ||
− | В алгоритме требуется знать для двух произвольных работ, зависит ли, возможно, не непосредственно, одна от другой. Для этого нужно транзитивно замкнуть граф по отношению зависимости. Это можно сделать несколькими способами. Первый и самый простой {{---}} за <tex>O(n^3)</tex> алгоритмом Флойда- | + | В алгоритме требуется знать для двух произвольных работ, зависит ли, возможно, не непосредственно, одна от другой. Для этого нужно транзитивно замкнуть граф по отношению зависимости. Это можно сделать несколькими способами. Первый и самый простой {{---}} за <tex>\mathcal{O}(n^3)</tex> алгоритмом Флойда-Уоршелла. Второй {{---}} при помощи метода четырех русских за <tex>\mathcal{O}(\dfrac{n^3}{\log n})</tex>. Третий {{---}} применить алгоритм Фишера-Мейера для построения замыкания графа за <tex>\mathcal{O}(n^{\log_2 7})</tex>. |
+ | |||
+ | При подсчете вынужденных дедлайнов, за <tex>\mathcal{O}(n)</tex> считается вынужденный дедлайн одной работы. Так как всего работ <tex>n</tex>, суммарное время подсчета вынужденных дедлайнов {{---}} <tex>\mathcal{O}(n^2)</tex>. | ||
+ | |||
+ | При, непосредственно, составлении расписания, на каждом шаге за <tex>\mathcal{O}(n)</tex> обрабатываются одна или две работы. Значит, все работы будут обработаны также за <tex>\mathcal{O}(n^2)</tex>. | ||
− | + | Итоговая сложность {{---}} <tex>\mathcal{O}(TrCl + n^2)</tex>. | |
− | + | == См. также == | |
+ | * [[PpmtnriLmax|<tex>P \mid pmtn, r_i \mid L_{max}</tex>]] | ||
− | + | ==Источники информации== | |
+ | * M.J. Fischer and A.R. Meyer, [http://rjlipton.files.wordpress.com/2009/10/matrix1971.pdf «Boolean Matrix Multiplication and Transitive Closure»]. | ||
+ | * P. Brucker. «Scheduling Algorithms» (2006), 5th edition, стр. 145-149. | ||
− | + | [[Категория: Алгоритмы и структуры данных]] | |
− | [ | + | [[Категория: Теория расписаний]] |
Текущая версия на 19:35, 4 сентября 2022
Задача: |
Даны два одинаковых станка, на которых необходимо обработать Каждую деталь можно обрабатывать на любом станке. Время, необходимое для обработки любой детали, одинаково и равно одному. Для каждой детали известны момент времени, до которого необходимо закончить работу над этой деталью — детали. , а также номера деталей, зависимых от нее. Необходимо минимизировать максимальное опоздание, где опоздание рассчитывается как разность между временем, когда была закончена обработка детали, и временем дедлайна для этой | деталей.
Содержание
Описание алгоритма
Полагаем, что ребра в графе ориентированы от работы, к работам, зависимым от нее. Введем понятие вынужденного дедлайна
— максимальное время, до которого необходимо выполнить -ю работу, чтобы успеть выполнить все работы из , где — множество работ, зависящих (не обязательно непосредственно) от -й работы. Заметим, что эта величина может принимать отрицательные значения. Обозначим через количество работ из , таких что .Утверждение: |
Пусть уже посчитаны работы для всех . Тогда, если , то -я работа
должна быть закончена до . |
Рассмотрим все работы , для которых . Все эти работы будут выполнены после окончания обработки детали с номером . Для них . Пусть работу закончили выполнять в момент времени . Нужно до момента времени выполнить ещё работ. Так как в нашем распоряжении находятся две машины, то время их выполнения будет не менее, чем . Поскольку необходимо выполнить все эти работы до , то -я работа должна быть закончена до момента времени . |
Тогда финально получаем формулу для вычисления «вынужденного» дедлайна для
-й работы: , где . Для вершин, исходящая степень которых равна нулю, по определению вынужденного дедлайна, считаем его равным обычному дедлайну. Для подсчета вынужденных дедлайнов будем поддерживать список , содержащий вершины, отсортированные в порядке неубывания дедлайнов. Дедлайн равен вынужденному дедлайну, если он уже посчитан, и обычному — в противном случае. Будем рассматривать вершины в порядке, обратном топологической сортировке графа, то есть, начиная с вершин нулевой исходящей степени. Пусть на текущем шаге мы рассматриваем работу с номером . Перебирая вершины из в порядке списка , пересчитываем вынужденный дедлайн для -й вершины по формуле, указанной выше, после чего обновляем дедлайн этой вершины в списке .После подсчета вынужденных дедлайнов, оптимальное расписание считается жадным алгоритмом. На каждом шаге на для обработки на станках выбираются работы с минимальным вынужденным дедлайном, для которых все необходимые работы уже выполнены. Одновременно с этим считается максимальное опоздание.
Доказательство корректности
Утверждение (#1): |
В расписании с обычными дедлайнами нет опозданий тогда и только тогда, когда нет опозданий в расписании с
вынужденными дедлайнами. |
Поскольку вынужденный дедлайн не нарушен, то, больший его обычный дедлайн, также не будет нарушен. По определению вынужденного дедлайна, — максимальное время окончания работы , при котором ещё можно успеть выполнить все работы из . Значит, если для был нарушен вынужденный дедлайн, то не все работы из выполнены вовремя, то есть был нарушен хотя бы один обычный дедлайн, что противоречит условию. Более формально, пусть был нарушен вынужденный дедлайн. Найдём работу с нарушенным вынужденным дедлайном, такую, что — не нарушено. Это всегда можно сделать в силу ацикличности графа. Рассмотрим формулу для подсчёта вынужденного дедлайна: , где .Минимум достигатся либо на противоречит условии выбора , что невозможно в силу того, что обычные дедлайны не нарушены, либо на каком-то . В этом случае, . Значит, если нарушено, то будет также нарушен вынужденный дедлайн для какого-то , так как осталось меньше, чем единиц времени. Это . |
Утверждение (#2): |
Если существует расписание без опоздание, то приведенный выше алгоритм найдет такое расписание. |
Пусть — расписание, построенное этим алгоритмом, где — время начала обработки -й детали. Пусть в этом расписании существует работа, опаздывающая по обычным дедлайнам. Согласно утверждению 1, в этом расписании также существует работа, опаздывающая по "вынужденным" дедлайнам. Пусть — такая работа с минимальным временем начала, то есть, удовлетворяющая следующему условию: . Следуя алгоритму, в каждый момент времени , такой что , хотя бы одна работа с номером , такая что должна быть выполнена, так как, иначе, по алгоритму, вместо -й на этом шаге была бы выбрана работа , имеющая меньшее и, по построению модифицированных дедлайнов, независимая от . Рассмотрим два случая.Первый случай: в какой-то момент времени только одна работа с номером , такая что выполнена. Выберем максимальное время , такое что , обладающее таким свойством. Тогда для всех работ c номером , которые выполнялись в момент времени с до выполняется , кроме того, ни один станок не простаивал в течении этого периода. Все работы , выполненные в период , а также, работа , должны быть зависимы от , потому что, иначе, только должна быть выполнена до момента времени . Так как было опоздание,
Из определения вынужденных дедлайнов, Значит, работа тоже опоздала, что противоречит минимальности выбора .Второй случай: в каждый момент времени такой, что выполняются две работы. По написанному выше, для всех этих работ , выполняется .Тогда есть хотя бы Их невозможно сделать за работ таких, что . времени, а значит, в каждом таком расписании есть опоздание. |
Утверждение (#3): |
При сдвиге всех на , сдвинутся также на это число. |
Для работ, от которых ничего не зависит, по определению , а, значит, для них утверждение верно.Рассмотрим остальные в порядке топологической сортировки. Тогда, по индукции, для всех потомков рассматриваемой вершины утверждение будет верно. Также, так как ,Вынеся за минимум общее слагаемое, по определению вынужденных дедлайнов, получим искомую формулу для . |
Теорема: |
Алгоритм строит оптимальное расписание. |
Доказательство: |
Пускай каким-то образом было вычислено оптимальное значение . Тогда, по второму утверждению, если сдвинуть все дедлайны на , то алгоритм получит для них оптимальное расписание.По третьему утверждению, для любого сдвига будет получено расписание с одним и тем же опозданием. Значит, для сдвига на В силу того, что для любого сдвига будет построено оптимальное расписание, алгоритм находит оптимальное расписание. оно также будет оптимальным. |
Сложность алгоритма
В алгоритме требуется знать для двух произвольных работ, зависит ли, возможно, не непосредственно, одна от другой. Для этого нужно транзитивно замкнуть граф по отношению зависимости. Это можно сделать несколькими способами. Первый и самый простой — за
алгоритмом Флойда-Уоршелла. Второй — при помощи метода четырех русских за . Третий — применить алгоритм Фишера-Мейера для построения замыкания графа за .При подсчете вынужденных дедлайнов, за
считается вынужденный дедлайн одной работы. Так как всего работ , суммарное время подсчета вынужденных дедлайнов — .При, непосредственно, составлении расписания, на каждом шаге за
обрабатываются одна или две работы. Значит, все работы будут обработаны также за .Итоговая сложность —
.См. также
Источники информации
- M.J. Fischer and A.R. Meyer, «Boolean Matrix Multiplication and Transitive Closure».
- P. Brucker. «Scheduling Algorithms» (2006), 5th edition, стр. 145-149.