Opij1sumwu — различия между версиями
(→Доказательство корректности) |
(→Псевдокод) |
||
Строка 12: | Строка 12: | ||
==Псевдокод== | ==Псевдокод== | ||
− | Предполагаем, что перед началом выполнения алгоритма выполняется, что | + | Предполагаем, что перед началом выполнения алгоритма выполняется, что <tex>m \leqslant d_{1} \leqslant d_{2} \leqslant ... \leqslant d_{n}</tex>. Все работы, дедлайн которых меньше <tex>m</tex>, мы в любом случае выполнить без штрафа не успеем, поэтому их изначально можно отнести к просроченным. |
− | |||
− | S = <tex>\varnothing</tex> | + | <tex>S</tex> {{---}} множество непросроченных работ, <tex>Check</tex> {{---}} функция, решающая задачу [[Opij1di|<tex> O \mid p_{i,j} = 1, d_i \mid - </tex>]]. |
+ | |||
+ | S = <tex>\varnothing</tex> | ||
'''for''' i = 1 to n | '''for''' i = 1 to n | ||
− | S = <tex> S \cup \{i\} </tex> | + | S = <tex> S \cup \{i\} </tex> |
− | '''if''' ''not'' | + | '''if''' ''not'' Check(s) : |
− | найти такое <tex>k</tex>, что <tex>w_{k} = \min \{ w_{j} \mid j \in S\}</tex> | + | найти такое <tex>k</tex>, что <tex>w_{k} = \min \{ w_{j} \mid j \in S\}</tex> |
− | S = <tex>S \setminus \{k\}</tex> | + | S = <tex>S \setminus \{k\}</tex> |
==Доказательство корректности== | ==Доказательство корректности== |
Версия 19:57, 13 мая 2016
Задача: |
Дано | одинаковых станков, которые работают параллельно, и работ, которые необходимо выполнить в произвольном порядке на всех станках. Любая работа на любом станке выполняется за единицу времени. Для каждой работы есть время окончания — время, до которого она должна быть выполнена. Требуется минимизировать , то есть суммарный вес всех просроченных работ.
Содержание
Алгоритм
Идея алгоритма состоит в том, что на шаге
строим оптимальное решение для первых работ с наименьшими дедлайнами.Пусть работы отсортированы в порядке возрастания дедлайнов. Пусть мы уже рассмотрели первые
работ, тогда множество содержит только те работы, которые мы успеваем выполнить в порядке возрастания дедлайнов при оптимальном расписании. Рассмотрим работу . Если мы ее успеваем выполнить данную работу, до наступления дедлайна, то добавим в множество и получим множество . Если же работу мы не успеваем выполнить до дедлайна, то найдем в работу c наименьшим весом и заменим ее на работу .Таким образом, рассмотрев все работы, мы получим
— множество работ, которые мы успеваем выполнить до наступления их дедлайнов, причем вес просроченных работ будет наименьшим. От порядка выполнения просроченных работ ничего не зависит, поэтому расположить в расписании их можно произвольным образом.Псевдокод
Предполагаем, что перед началом выполнения алгоритма выполняется, что
. Все работы, дедлайн которых меньше , мы в любом случае выполнить без штрафа не успеем, поэтому их изначально можно отнести к просроченным. — множество непросроченных работ, — функция, решающая задачуS =for i = 1 to n S = if not Check(s) : найти такое , что S =
Доказательство корректности
Утверждение: |
Алгоритм строит корректное расписание. |
Если мы успеваем выполнить очередную работу, то, очевидно, от ее добавления, расписание не может стать некорректным. В противном случае мы пытаемся заменить одну работу из множества | на текущую. Но это так же не может сделать наше расписание некорректным. Это следует из того, что мы рассматриваем работы в порядке неуменьшениях их дедлайнов. Пусть мы заменяем работу на работу . Но , следовательно, если мы успевали выполнить работу , то успеем выполнить и работу .