Opij1sumwu — различия между версиями
м (→Псевдокод) |
(→Доказательство корректности) |
||
| Строка 23: | Строка 23: | ||
==Доказательство корректности== | ==Доказательство корректности== | ||
| + | |||
| + | {{Утверждение | ||
| + | |statement=Алгоритм строит корректное расписание. | ||
| + | |proof=Если мы успеваем выполнить очередную работу, то, очевидно, от ее добавления, расписание не может стать некорректным. В противном случае мы пытаемся заменить одну работу из множества <tex> S </tex> на текущую. Но это так же не может сделать наше расписание некорректным. Это следует из того, что мы рассматриваем работы в порядке неуменьшениях их дедлайнов. Пусть мы заменяем работу <tex> k </tex> на работу <tex> i </tex>. Но <tex> d_{k} \leqslant d_{i} </tex>, следовательно, если мы успевали выполнить работу <tex> k </tex>, то успеем выполнить и работу <tex> i </tex>. | ||
| + | }} | ||
==Время работы== | ==Время работы== | ||
Версия 19:25, 13 мая 2016
| Задача: |
| Дано одинаковых станков, которые работают параллельно, и работ, которые необходимо выполнить в произвольном порядке на всех станках. Любая работа на любом станке выполняется за единицу времени. Для каждой работы есть время окончания — время, до которого она должна быть выполнена. Требуется минимизировать , то есть суммарный вес всех просроченных работ. |
Содержание
Алгоритм
Идея алгоритма состоит в том, что на шаге строим оптимальное решение для первых работ с наименьшими дедлайнами.
Пусть работы отсортированы в порядке возрастания дедлайнов. Пусть мы уже рассмотрели первые работ, тогда множество содержит только те работы, которые мы успеваем выполнить в порядке возрастания дедлайнов при оптимальном расписании. Рассмотрим работу . Если мы ее успеваем выполнить данную работу, до наступления дедлайна, то добавим в множество и получим множество . Если же работу мы не успеваем выполнить до дедлайна, то найдем в работу c наименьшим весом и заменим ее на работу .
Таким образом, рассмотрев все работы, мы получим — множество работ, которые мы успеваем выполнить до наступления их дедлайнов, причем вес просроченных работ будет наименьшим. От порядка выполнения просроченных работ ничего не зависит, поэтому расположить в расписании их можно произвольным образом.
Псевдокод
Предполагаем, что перед началом выполнения алгоритма выполняется, что 1 \leqslant d_{1} \leqslant d_{2} \leqslant ... \leqslant d_{n}. Все работы, дедлайн которых равен 0, мы в любом случае выполнить без штрафа не успеем, поэтому их изначально можно отнести к просроченным. S — множество непросроченных работ, Check — функция, решающая задачу .
S = ; for i = 1 to n S = ; if not check(s) : найти такое , что ; S = ;
Доказательство корректности
| Утверждение: |
Алгоритм строит корректное расписание. |
| Если мы успеваем выполнить очередную работу, то, очевидно, от ее добавления, расписание не может стать некорректным. В противном случае мы пытаемся заменить одну работу из множества на текущую. Но это так же не может сделать наше расписание некорректным. Это следует из того, что мы рассматриваем работы в порядке неуменьшениях их дедлайнов. Пусть мы заменяем работу на работу . Но , следовательно, если мы успевали выполнить работу , то успеем выполнить и работу . |