Opij1sumwu — различия между версиями
(→Время работы) |
(→См. также) |
||
Строка 34: | Строка 34: | ||
==См. также== | ==См. также== | ||
+ | * [[Opij1di|<tex> O \mid p_{i,j} = 1, d_i \mid - </tex>]] | ||
+ | * [[Opi1sumu|<tex>O \mid p_{ij} = 1 \mid \sum U_i</tex>]] | ||
==Источники информации== | ==Источники информации== |
Версия 14:14, 14 мая 2016
Задача: |
Дано | одинаковых станков, которые работают параллельно, и работ, которые необходимо выполнить в произвольном порядке на всех станках. Любая работа на любом станке выполняется за единицу времени. Для каждой работы есть время окончания — время, до которого она должна быть выполнена. Требуется минимизировать , то есть суммарный вес всех просроченных работ.
Содержание
Алгоритм
Идея алгоритма состоит в том, что на шаге
строим оптимальное решение для первых работ с наименьшими дедлайнами.Пусть работы отсортированы в порядке возрастания дедлайнов. Пусть мы уже рассмотрели первые
работ, тогда множество содержит только те работы, которые мы успеваем выполнить в порядке возрастания дедлайнов при оптимальном расписании. Рассмотрим работу . Если мы ее успеваем выполнить данную работу, до наступления дедлайна, то добавим в множество и получим множество . Если же работу мы не успеваем выполнить до дедлайна, то найдем в работу c наименьшим весом и заменим ее на работу .Таким образом, рассмотрев все работы, мы получим
— множество работ, которые мы успеваем выполнить до наступления их дедлайнов, причем вес просроченных работ будет наименьшим. От порядка выполнения просроченных работ ничего не зависит, поэтому расположить в расписании их можно произвольным образом.Псевдокод
Предполагаем, что перед началом выполнения алгоритма выполняется, что
. Все работы, дедлайн которых меньше , мы в любом случае выполнить без штрафа не успеем, поэтому их изначально можно отнести к просроченным. — множество непросроченных работ, — функция, решающая задачуS =for i = 1 to n S = if not Check(s) : найти такое , что S =
Доказательство корректности
Утверждение: |
Алгоритм строит корректное расписание. |
Если мы успеваем выполнить очередную работу, то, очевидно, от ее добавления, расписание не может стать некорректным. В противном случае мы пытаемся заменить одну работу из множества | на текущую. Но это так же не может сделать наше расписание некорректным. Это следует из того, что мы рассматриваем работы в порядке неуменьшениях их дедлайнов. Пусть мы заменяем работу на работу . Но , следовательно, если мы успевали выполнить работу , то успеем выполнить и работу .
Время работы
Время работы зависит от того, на сколько быстро мы будем добавлять, находить и удалять работы из множества двоичную кучу или красно-черное дерево и тогда все нужные нам операции будут выполняться за . Тогда время алгоритма будет . Так как , то время алгоритма
. В качестве можно использовать