Opij1sumwu — различия между версиями
(→Псевдокод) |
(→Время работы) |
||
Строка 31: | Строка 31: | ||
==Время работы== | ==Время работы== | ||
+ | Время работы зависит от того, на сколько быстро мы будем добавлять, находить и удалять работы из множества <tex>S</tex>. В качестве <tex>S</tex> можно использовать [[Двоичная куча | двоичную кучу]] или [[Красно-черное дерево | красно-черное дерево]] и тогда все нужные нам операции будут выполняться за <tex>O(\log n)</tex>. Тогда время алгоритма будет <tex>O(n*(\log n + T(Check)))</tex>. Так как <tex>T(Check)=O(nm)</tex>, то время алгоритма <tex>O(n^2*m)</tex> | ||
==См. также== | ==См. также== | ||
==Источники информации== | ==Источники информации== |
Версия 14:13, 14 мая 2016
Задача: |
Дано | одинаковых станков, которые работают параллельно, и работ, которые необходимо выполнить в произвольном порядке на всех станках. Любая работа на любом станке выполняется за единицу времени. Для каждой работы есть время окончания — время, до которого она должна быть выполнена. Требуется минимизировать , то есть суммарный вес всех просроченных работ.
Содержание
Алгоритм
Идея алгоритма состоит в том, что на шаге
строим оптимальное решение для первых работ с наименьшими дедлайнами.Пусть работы отсортированы в порядке возрастания дедлайнов. Пусть мы уже рассмотрели первые
работ, тогда множество содержит только те работы, которые мы успеваем выполнить в порядке возрастания дедлайнов при оптимальном расписании. Рассмотрим работу . Если мы ее успеваем выполнить данную работу, до наступления дедлайна, то добавим в множество и получим множество . Если же работу мы не успеваем выполнить до дедлайна, то найдем в работу c наименьшим весом и заменим ее на работу .Таким образом, рассмотрев все работы, мы получим
— множество работ, которые мы успеваем выполнить до наступления их дедлайнов, причем вес просроченных работ будет наименьшим. От порядка выполнения просроченных работ ничего не зависит, поэтому расположить в расписании их можно произвольным образом.Псевдокод
Предполагаем, что перед началом выполнения алгоритма выполняется, что
. Все работы, дедлайн которых меньше , мы в любом случае выполнить без штрафа не успеем, поэтому их изначально можно отнести к просроченным. — множество непросроченных работ, — функция, решающая задачуS =for i = 1 to n S = if not Check(s) : найти такое , что S =
Доказательство корректности
Утверждение: |
Алгоритм строит корректное расписание. |
Если мы успеваем выполнить очередную работу, то, очевидно, от ее добавления, расписание не может стать некорректным. В противном случае мы пытаемся заменить одну работу из множества | на текущую. Но это так же не может сделать наше расписание некорректным. Это следует из того, что мы рассматриваем работы в порядке неуменьшениях их дедлайнов. Пусть мы заменяем работу на работу . Но , следовательно, если мы успевали выполнить работу , то успеем выполнить и работу .
Время работы
Время работы зависит от того, на сколько быстро мы будем добавлять, находить и удалять работы из множества двоичную кучу или красно-черное дерево и тогда все нужные нам операции будут выполняться за . Тогда время алгоритма будет . Так как , то время алгоритма
. В качестве можно использовать